root远程访问授权

mysql> SHOW
DATABASES;

+--------------------+

| Database           |

+--------------------+

| information_schema
|

| mysql              |

| performance_schema
|

| sys                |

+--------------------+

4 rows in set (0.00
sec)

mysql> use
mysql;

Database
changed

--允许在Liang-PC上以root/123456登录

mysql> grant all
privileges on *.* to 'root'@'Liang-PC' identified by '123456' with grant
option;

Query OK, 0 rows affected, 1
warning (0.02 sec)

mysql> flush
privileges;

Query OK, 0 rows affected (0.00
sec)

mysql> select host,user from
user;

+-----------+---------------+

| host      | user          |

+-----------+---------------+

| liang-pc  | root          |

| localhost | mysql.session
|

| localhost | mysql.sys     |

| localhost | root          |

+-----------+---------------+

4 rows in set (0.00
sec)

MySQL Workbench 8.0
CE

Ctrl+Enter  运行当前语句

#查询数据库连接

show full
processlist;

show status like
'%Max_used_connections%';

show status like
'%Threads_connected%'; #当前连接数

show status like '%table_lock%';
#表锁定

show status like
'innodb_row_lock%'; #行锁定

show status like '%qcache%';  #查询缓存情况

show variables like
"%query_cache%";

SHOW STATUS LIKE
'Qcache%';

show variables like
"%binlog%";

show status like
'Aborted_clients'; #由于客户没有正确关闭连接已经死掉,已经放弃的连接数量

show variables like
'%max_connections%'; #查看最大连接数量

show variables like '%timeout%';
#查看超时时间

show variables like 'log_%';  #查看日志是否启动

mysql注释符

单行注释:#abc  或 --
abc

这里注意oracle/mssql的--注释不需要空格,但mysql的一定要有空格。

多注释:

/*

Abc

*/

创建数据库/Schemas

-- 查看
datadir 位置

show variables like
'%dir%';

show variables
like 'datadir';

Show
databases;

等价

select schema_name from
information_schema.schemata

use
mysql;

show
tables;

SHOW COLUMNS FROM
user;

等价

describe
user;

1、使用create database语句创建数据库

CREATE DATABASE IF NOT EXISTS
study DEFAULT CHARSET utf8;

create database if not exists
study default character set = 'utf8';

2、查看创建的DB的字符集

select
schema_name,default_character_set_name

from information_schema.schemata where schema_name =
'study';

3、通过链接符,改变数据库物理位置

a).关闭服务

b).移动目录

c).mklink /j
"C:\ProgramData\MySQL\MySQL Server 5.7\Data\study"
D:\mysqldata\study

d).启动服务

findstr "^[^#]" "C:\ProgramData\MySQL\MySQL
Server 5.7\my.ini"

4、创建表

CREATE TABLE `study`.`a_temp01`
(

`id` INT NULL,

`text` VARCHAR(45)
NULL);

创建用户并授权

CREATE USER 'ustudy'@'%'
IDENTIFIED BY 'ustudy';

flush
privileges;

select host,user from
mysql.user;

GRANT all privileges ON study.* TO
'ustudy'@'%';

方法分成三种:INSERT
USER表的方法、CREATE USER的方法、GRANT的方法,最终在mysql.user中形成记录。

账号的组成方式:用户名+主机(所以可以出现重复的用户名,跟其他的数据库不一样)

用户名:16字符以内.

主机名:可以用主机名和IP地址,也可以用通配符

通配符说明:172.18.10.%(IP地址为172.18.10段的所有IP地址都可以访问)

CREATE USER的方法

CREATE USER 'username'@'host'
[IDENTIFIED BY 'PASSWORD'];

说明:该方法创建出来的用户只有连接数据库的权限,需要后续继续授权;

GRANT的方法

GRANT
privileges ON databasename.tablename TO 'username'@'host' [identified by
‘password’ WITH GRANT OPTION];

privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL

databasename:数据库名

tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*

当数据库存在用户的时候GRANT会对用户进行授权,但当数据库不存在该用户的时候,就会创建相应的用户并进行授权。

例子:

mysql>grant
select,insert,update,delete on test.hr to john@192.168.10.1 INSERT
USER表的方法123';

说明:给主机为192.168.10.1的用户john分配可对数据库test的hr表进行select,insert,update,delete,create,drop等操作的权限,并设定口令为123。

mysql>grant all privileges on
test.* to joe@192.168.10.1 identified by
'123';

说明:给主机为192.168.10.1的用户john分配可对数据库test所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on
*.* to john@192.168.10.1 identified by '123';

说明:给主机为192.168.10.1的用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

mysql>grant all privileges on
*.* to john@localhost identified by '123';

说明:用户john分配可对所有数据库的所有表进行所有操作的权限,并设定口令为123。

查看用户权限:等价

SHOW grants
FOR ustudy;

SHOW GRANTs
FOR 'ustudy'@'%';

show CREATE database study; 这个可以看到创建study数据库时用到的一些参数。

show create table
study.a_temp01;    可以看到创建study.a_temp01表时用到的一些参数

INSERT USER表的方法

插入方法:创建用户

mysql> insert into
user (host,user,password) values
('%','john',password('123'));

mysql>flush
privileges;

SET
PASSWORD

设置与更改用户密码

SET PASSWORD FOR 'username'@'host'
= PASSWORD('newpassword');

如果是当前登陆用户用:

SET PASSWORD =
PASSWORD("newpassword");

撤销用户权限:由grant变REVOKE

REVOKE privilege ON
databasename.tablename FROM 'username'@'host';

删除用户

DROP USER
'username'@'host';

MySQL创建数据库与用户的更多相关文章

  1. mysql 创建数据库,添加用户,用户授权

    一.创建mysql数据库 1.创建数据库语法 --创建名称为"testdb"数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb ...

  2. Mysql创建数据库以及用户分配权限

    一.创建mysql数据库 1.创建数据库语法 --创建名称为“testdb”数据库,并设定编码集为utf8 CREATE DATABASE IF NOT EXISTS testdb DEFAULT C ...

  3. mysql创建数据库和用户

    create database sonar character set utf8 collate utf8_general_ci; flush privileges; grant all privil ...

  4. MySQL创建数据库及用户

    create database ${db_name} default charset utf8 COLLATE utf8_general_ci; grant all on ${db_name}.* t ...

  5. MySQL创建数据库,用户,赋予权限

    CREATE DATABASE 'voyager'; CREATE DATABASE `voyager`; CREATE USER 'dog'@'localhost' IDENTIFIED BY '1 ...

  6. MySQL创建数据库时指定编码utf8mb4和添加用户

    CREATE DATABASE `wordpress` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; CREATE DATABASE `wor ...

  7. mysql创建数据库用户

    连接mysql cmd--> mysql -hlocalhost -uroot -pmypassword 退出mysql mysql> quit 也可用exit或者 \q ======== ...

  8. MySQL 创建数据库

    MySQL 创建数据库 使用 mysqladmin 创建数据库 使用普通用户,你可能需要特定的权限来创建或者删除 MySQL 数据库. 所以我们这边使用root用户登录,root用户拥有最高权限,可以 ...

  9. 五、MySQL 创建数据库

    MySQL 创建数据库 我们可以在登陆 MySQL 服务后,使用 create 命令创建数据库,语法如下: CREATE DATABASE 数据库名; 以下命令简单的演示了创建数据库的过程,数据名为 ...

随机推荐

  1. Sign Up Account In CloudAMQP

    CloudAMQP 有多种账号级别,请参考下面的链接的内容访问你可以注册的级别:https://www.cloudamqp.com/plans.html 作为测试来说,你可以注册免费的的消息. 你可以 ...

  2. ES6与ES5对比 模板字符串

    var title = '你好' ES5 var tpl1 = '<div>' + '<span>' + title + '</span>' '</div&g ...

  3. [cf div 2 706E] Working routine

    [cf div 2 706E] Working routine Vasiliy finally got to work, where there is a huge amount of tasks w ...

  4. Win10系列:C#应用控件基础11

    RichEditBox控件 富文本格式是一种跨平台的文档格式,在这种格式的文档中可以编辑文本.图片.链接等内容.通过RichEditBox控件可以对富文本格式的文档进行编辑. 在XAML文件中,Ric ...

  5. 点击事件target

    1.场景:需要写一个弹出框来容纳登录界面,类似于百度的登录框   问题:使用  display: none/block  进行弹出框的显示和隐藏,设立点击事件   onclick  进行触发,但是点击 ...

  6. react+classnames

    之前做项目的时候一直不知道有不知道有classnames这个东西,一直用的都是字符串拼接,感觉用的很别扭. classnames用法和angular1.x及vue差不多,所以用起来会比较顺手 1)安装 ...

  7. 【golang】kafka

    这篇博客是用来记录用go安装及操作kafka库的时候踩到的坑~ 安装kafka库 首先我参考了博客:https://blog.csdn.net/tflasd1157/article/details/8 ...

  8. spring注解实现防盗链拦截

    首先配置 applicationContext.xml, 添加 <!-- 启用 @AspectJ --> <aop:aspectj-autoproxy /> 新建Java工具类 ...

  9. 二十六. Python基础(26)--类的内置特殊属性和方法

    二十六. Python基础(26)--类的内置特殊属性和方法 ● 知识框架 ● 类的内置方法/魔法方法案例1: 单例设计模式 # 类的魔法方法 # 案例1: 单例设计模式 class Teacher: ...

  10. 软工作业No.7 甜美女孩第五周--测试与发布

    Alpha版本发布说明 一.功能介绍 本团队所做的多模式自定义2048是用来进行纸牌模式以及正常基础模式版本的2048小游戏的.Alpha版本具有的功能大体如下: 初始界面- 纸牌模式- 基础模式- ...