目录
DCL-介绍
DCL-管理用户
1.查询用户
use mysql ;
select * from user ;
select * from mysql.user ; --这里为什么是mysql.user,你要么用上面的组合,要么用下面的语句才能访问到user,因为user表是在mysql这个数据库中的,你要先切换到那个数据库中,或者用这个语句
执行如下:
2.创建用户
CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';
3.修改用户密码
ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码' ;
4.删除用户
DROP USER '用户名'@'主机名' ;
案例:
1.创建用户itczh, 只能够在当前主机localhost访问, 密码123456 ;
create user 'itczh'@'localhost' identified by '123456' ;
执行如下:
2.创建用户czh, 可以在任意主机访问该数据库, 密码123456 ;
create user 'czh'@'%' identified by '123456' ;
执行如下:
3.修改用户czh的访问密码为1234 ;
alter user 'czh'@'%' identified with mysql_native_password by '1234';
执行如下:
测试:
4.删除 itczh@localhost 用户
drop user 'itczh'@'localhost';
执行如下:
此时可以发现用户itczh已经被删除了
DCL - 权限控制
MySQL中定义了很多种权限,但是常用的就以下几种:
权限 | 说明 |
ALL, ALL PRIVILEGES | 所有权限 |
SELECT | 查询数据 |
INSERT | 插入数据 |
UPDATE | 修改数据 |
DELETE | 删除数据 |
ALTER | 修改表 |
DROP | 删除数据库/表/视图 |
CREATE | 创建数据库/表 |
上述只是简单罗列了常见的几种权限描述,其他权限描述及含义,可以直接参考官方文档。
1.查询权限
SHOW GRANTS FOR '用户名'@'主机名' ;
2.授予权限
GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';
3.撤销权限
REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名';
案例:
1.查询 'czh'@'%' 用户的权限
show grants for 'czh'@'%';
执行如下:
2.授予 'czh'@'%' 用户test数据库所有表的所有操作权限 (授权的关键字grant)
grant all on test.* to 'czh'@'%';
执行如下:
3.撤销 'czh'@'%' 用户的test数据库的所有权限
revoke all on test.* from 'czh'@'%';
执行如下: