基础—SQL—DCL(数据控制语言)之权限控制

一、引言

学习完上篇博客,我们创建了用户之后,发现用户可以登录上 mysql 但是基本上不能访问任何的数据库,只能访问一个系统库。原因就是:用户创建好了之后,并没有给用户分配权限。接下来就会去学习和讲解DCL当中如何控制权限。

(1)MySQL当中定义了很多种权限,但是常用的就以下的几种权限:

其它的权限大家可以去官方文档查看详细的说明。

二、DCL------权限控制

主要通过介绍一下三张操作。

1、查询权限
  • SHOW GRANTS FOR '用户名'@'主机名';

注意:

grant:授予、准许

2、授予权限
  • GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'主机名';

注意:

1、如果我们要给所有的数据库、所有的表来赋予权限。就写 ' *.* '

3、撤销权限
  • REVOKE 权限列表 ON 数据库名.表名 FROM '用户名'@'主机名';

注意:

revoke :撤销、废除。记住 ON 后面注意你要撤销的是哪一个数据库、哪一张表上的权限,然后从每一个用户的权限上面来撤销这个权限。后面加个关键字:FROM

三、案例

打开工具 DataGrip ,然后打开控制台。

(1)查询权限

FOR 后面指定的是你要查询的是哪一个用户的权限,比如我现在查询 heima用户。

sql 复制代码
SHOW GRANTS FOR 'heima'@'%';
(2)授予权限
sql 复制代码
GRANT ALL ON test.* TO 'heima'@'%';

执行查询权限

这个时候再去命令行检查一下。

(3)撤销查询
sql 复制代码
REVOKE ALL ON test.* FROM 'heima'@'%';

此时,打开命令行退出之前的操作。重新用用户 heima登录连接数据库查看。

这就是DCL关于权限控制的三种操作。

注意:

1、多个权限之间,使用逗号分隔。

2、授权时,数据库名和表名可以使用*进行通配,代表所有。例如:*.* :代表我们要给这个用户分配 所有数据库所有表的所有权限,这就类似于是一个超级管理员。

相关推荐
冰暮流星1 分钟前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发26 分钟前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐39 分钟前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
斯普信专业组1 小时前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
Elastic 中国社区官方博客1 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.1 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐1 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
啦啦啦_99991 小时前
Redis-0-业务逻辑
数据库·redis·缓存
证榜样呀1 小时前
2026 中专大数据技术专业可考的证书有哪些,必看!
大数据·sql