目录
介绍:
全称是data control language(数据控制语言),用来管理数据库用户、控制数据库的访问权限。
管理用户
1:查询用户
use mysql;
select * from user;
2:创建用户
create user '用户名'@'主机名' identified by '密码';
3:修改用户密码
alter user '用户名'@'主机名' identified with mysql_native_password by '新密码';
4:删除用户
drop user '用户名'@'主机名';
注意:
主机名可以使用%通配
这类SQL开发人员的操作的比较少,主要是DBA(苏数据库管理员)使用。
这里我们看到mysql库 里的user表
我们来创建一个用户
刷新试试
那么我们来测试一下
成功的哈!
它没有权限访问到其他数据库
我们再来创建一个可以在任意主机访问该数据库。
现在,我们修改用户 leng 的密码
来到删除用户
可以看到是少了的。
权限控制
mysql中定义了很多种权限,但是常用的就一下这几种:
权限 | 说明 |
ALL,ALL PRIVILEGES | 所有权限 |
SELECT | 查询数据 |
INSERT | 插入数据 |
UPDATE | 修改数据 |
DELETE | 删除数据 |
ALTER | 修改表 |
DROP | 删除数据库/表/视图 |
CREATE | 创建数据库/表 |
查询权限
show grants for '用户名'@'主机名';
授予权限
grant 权限列表 on 数据库名、表名 to '用户名'@'主机名';
撤销权限
revoke 权限列表 on 数据库名、表名 from '用户名'@'主机名';
注意:
多个权限之间,使用逗号分隔
授权时,数据库名和表名可以使用*进行通配,代表所有
这个是只有一个仅仅登上数据库的权限,没有其他的权限
下面就给它授权
这里就给了它全部的权限
下面就撤销
总结
到这里,SQL的通用语法和分类就结束了。