0

0

mysql权限和角色有什么区别_mysql角色管理原理说明

P粉602998670

P粉602998670

发布时间:2026-02-15 08:40:03

|

930人浏览过

|

来源于php中文网

原创

权限是最细粒度操作控制单元,角色是权限容器;角色需显式激活才生效;权限校验走授权表但含间接路径;用户与角色语法对称但语义不同,角色不可登录、不可revoke、需drop删除。

mysql权限和角色有什么区别_mysql角色管理原理说明

权限是操作能力,角色是权限的打包容器

权限(Privilege)是数据库里最细粒度的控制单元,比如 SELECTINSERTDROP,它直接决定“能不能执行某条 SQL”。角色(Role)本身不干活,只是把一堆权限捆在一起,像一个可复用的权限模板。用户不能直接“拥有角色”,而是通过 GRANT role_name TO user@host 获得角色所含的所有权限——本质是权限继承,不是逻辑分组。

MySQL 角色管理依赖显式激活,不自动生效

这是最容易踩坑的地方:创建角色并授权后,用户登录并不会自动获得该角色权限。必须手动激活,否则 SELECT 都会报 Access denied

  • 会话级激活:SET ROLE role_dev;(仅当前连接有效)
  • 默认激活(推荐):SET DEFAULT ROLE role_dev TO 'dev01'@'localhost';
  • 全局默认(8.0.16+):SET PERSIST default_role = 'role_dev';,影响新连接

没执行 SET DEFAULT ROLE 就以为权限已生效,是线上权限故障的高频原因。

MusicArt
MusicArt

AI音乐生成器

下载

角色权限检查仍走传统授权表,但叠加逻辑更复杂

MySQL 权限校验顺序仍是先查 mysql.user(全局)、再 mysql.db(库级)等系统表,但角色引入了“间接路径”:用户 → 角色 → 角色的权限记录(存于 mysql.role_edgesmysql.role_routine_grants 等新表)。这意味着:

  • 撤销角色权限时,要同时考虑直接授给用户的权限和角色带来的权限,避免残留
  • SHOW GRANTS FOR 'u'@'h' 默认只显示直接授予的权限,加 FOR u@h WITH ADMIN OPTION 才能看到角色链
  • 角色嵌套(A→B→C)在 8.0.20+ 才完全支持,低版本嵌套会静默失败

用户和角色在语法上几乎对称,但语义不可互换

你可以用 CREATE ROLE r1;CREATE USER u1@'%' IDENTIFIED BY 'pwd';,也能对两者都执行 GRANT SELECT ON db.* TO r1;,看起来一样——但关键区别在于:

  • 角色不能登录,没有密码字段,不能出现在 mysql.user 表中
  • 角色不能被 REVOKE ... FROM 直接删掉,必须先 DROP ROLE r1;
  • 用户可拥有多个角色,角色也可被多个用户持有,但角色之间不能循环授权(如 r1 → r2 → r1)

混淆用户与角色的生命周期管理,比如误删一个被广泛授予的角色,会导致一批用户瞬间失权,且无日志提示具体影响范围。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

943

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

375

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1636

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

369

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1211

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

583

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

434

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 833人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号