Mysql学习笔记之SQL-4

这篇文章开始介绍SQL语句的最后一个部分,DCL(Data Control Language)数据库控制语言。

1.简介

DCL英文全称是Data Control Language(数据控制语言),用来管理数据库用户、控制数据库的访
问权限。
这一部分比较简单,主要为数据库用户的管理和权限配置。通过DCL语句可以创建数据库用户,并为每个用户设置数据库权限。

2.用户管理

2.1 查询用户

mysql数据库的用户表保存在mysql库中的user表中,可以通过sql语句或者使用navicat查看。

SELECT * from mysql.`user`;

在这里插入图片描述
表中从第三列开始每一列代表一个权限,Y为拥有此项权限,N为没有此项权限。
注意
第一列的Host为访问权限, 如果为localhost, 仅代表只能够在当前本机访问,是不可以
远程访问的。User代表的是数据库的用户名。

2.2 创建用户

语法:

CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

案例
创建名为test的本地用户

CREATE USER 'test'@'localhost' IDENTIFIED BY '123456';

在这里插入图片描述
可以看到创建用户就在user表中添加了一条数据,并且默认是没有任何权限的。

2.3删除用户

DROP USER '用户名'@'主机名' ;

案例
删除test的本地用户

DROP USER 'test'@'localhost' ;

2.4修改用户密码

ALTER USER '用户名'@'主机名' IDENTIFIED WITH mysql_native_password BY '新密码' ;

案例
修改test的本地用户的密码为654321

ALTER USER 'test'@'localhost'  IDENTIFIED WITH mysql_native_password BY '654321' ;

3.权限管理

Mysql中的权限主要分为对数据的操作权限和对表的操作权限。
数据操作权限分为:

  • 查询权限
  • 修改权限
  • 插入权限
  • 删除权限

表操作权限分为:

  • 修改表
  • 删除数据库/表/视图
  • 创建表/数据库
    具体如下表所示:
权限说明
ALL所有权限
SELECT查询数据权限
INSERT插入数据权限
UPDATE更新数据权限
DELETE删除数据权限
ALTER修改表
DROP删除数据库/表/视图
CREATE创建数据库/表

3.1 授予权限

上面提到,创建用户后,默认是没有任何权限的,因此需要给用户赋予对应的权限。
语法:

 GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';

案例
给test授予test库所有权限

 GRANT ALL ON test.* TO 'test'@'localhost';

给test授予所有库的查询,删除,插入权限

 GRANT SELECT,INSERT,DELETE ON *.* TO 'test'@'localhost';
 -- 第一个*表示所有数据库,第二个*表示数据库中的所有表

3.2 撤销权限

语法:

REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名';

案例
撤销test用户test库的所有权限

 REVOKE ALL ON test.* FROM 'test'@'localhost';

撤销test所有库的查询,删除,插入权限

 REVOKE SELECT,INSERT,DELETE ON *.* FROM 'test'@'localhost';
 -- 第一个*表示所有数据库,第二个*表示数据库中的所有表

3.3 查询权限

语法:

SHOW GRANTS FOR '用户名'@'主机名' ;

案例
查询本地用户test的权限

SHOW GRANTS FOR 'test'@'localhost';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值