Mysql学习笔记之SQL-4

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

1.简介

DCL英文全称是Data Control Language(数据控制语言),用来管理数据库用户、控制数据库的访

问权限。

这一部分比较简单,主要为数据库用户的管理和权限配置。通过DCL语句可以创建数据库用户,并为每个用户设置数据库权限。

2.用户管理

2.1 查询用户

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

sql 复制代码
SELECT * from mysql.`user`;

表中从第三列开始每一列代表一个权限,Y为拥有此项权限,N为没有此项权限。
注意

第一列的Host为访问权限, 如果为localhost, 仅代表只能够在当前本机访问,是不可以

远程访问的。User代表的是数据库的用户名。

2.2 创建用户

语法:

sql 复制代码
CREATE USER '用户名'@'主机名' IDENTIFIED BY '密码';

案例

创建名为test的本地用户

sql 复制代码
CREATE USER 'test'@'localhost' IDENTIFIED BY '123456';

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

2.3删除用户

sql 复制代码
DROP USER '用户名'@'主机名' ;

案例

删除test的本地用户

sql 复制代码
DROP USER 'test'@'localhost' ;

2.4修改用户密码

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

案例

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

sql 复制代码
ALTER USER 'test'@'localhost'  IDENTIFIED WITH mysql_native_password BY '654321' ;

3.权限管理

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

数据操作权限分为:

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

表操作权限分为:

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

3.1 授予权限

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

语法:

sql 复制代码
 GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';

案例

给test授予test库所有权限

sql 复制代码
 GRANT ALL ON test.* TO 'test'@'localhost';

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

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

3.2 撤销权限

语法:

sql 复制代码
REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名';

案例

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

sql 复制代码
 REVOKE ALL ON test.* FROM 'test'@'localhost';

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

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

3.3 查询权限

语法:

sql 复制代码
SHOW GRANTS FOR '用户名'@'主机名' ;

案例

查询本地用户test的权限

sql 复制代码
SHOW GRANTS FOR 'test'@'localhost';
相关推荐
我的golang之路果然有问题17 小时前
mysql 个人笔记导出之-数据库时间戳问题以及增删改查
数据库·笔记·学习·mysql·分享·个人笔记
JH307317 小时前
我的笔记:怎么用 MySQL 的 EXPLAIN 来分析 SQL
笔记·sql·mysql
ybb_ymm17 小时前
如何通过跳板机链接mysql数据库
数据库·mysql
7ioik17 小时前
RC和RR隔离级别下MVCC的差异?
数据库·sql·mysql
luoluoal17 小时前
基于python的二维码生成算法研究和实现(源码+文档)
python·mysql·django·毕业设计·源码
高溪流17 小时前
2.Mysql相关概念 及 数据库操作
数据库·mysql
代码不停18 小时前
MySQL事务
android·数据库·mysql
IT_Octopus18 小时前
java 实体属性 Map 解决 mybatis-plus wrapper selectone 查mysql json类型为null 问题
java·mysql·mybatis
IT运维爱好者19 小时前
docker-compose部署MySQL主从复制集群
mysql·docker-compose
且去填词19 小时前
DeepSeek-R1 实战:数据分析
人工智能·python·mysql·语言模型·deepseek·structured data