MySQL Workbench中的权限设置不生效

 更新时间:2026年04月15日 09:23:18   作者:fundoit  
MySQL账号即使只被授予特定数据库权限,仍可能因拥有全局权限而查看所有数据库,本文分析该现象成因,提供排查方法,并给出三种解决方案,感兴趣的可以了解一下

🖼️现象:

这个test账号我只给了两个数据库权限,为什么它连接还是能看到其他数据库。下图是这个账号的设置。

test 账号能看到其他数据库,很可能是因为它拥有了某个“全局级别”的权限,比如 SHOW DATABASES。只要用户有任意一个全局权限,MySQL 就会允许他查看服务器上所有数据库的名字,这可能会造成一些安全风险。

🔑 为什么一个全局权限会导致看到所有数据库?

在 MySQL 中,权限的授予范围是分层级的。其中,“全局权限”(*.*)是所有权限里最高的一级。根据 MySQL 的官方设计,只要用户拥有了任何一个全局权限,系统在执行 SHOW DATABASES 命令时,就会向其展示服务器上所有数据库的名称。

🕵️‍♂️ 排查问题:test 账号拥有哪些权限?

按照下面的步骤来检查 test 账号的具体权限,应该就能找到是哪个全局权限导致了问题。

  1. 登录数据库:用 root 或其他有管理权限的账号登录 MySQL。

    mysql -u root -p
  2. 查看用户权限:在 MySQL 命令行中,执行以下 SQL 命令:

    SHOW GRANTS FOR 'test'@'%';

    请注意:账号由用户名 (test) 和主机名 (%) 共同组成。

  3. 分析返回结果:重点检查输出中是否包含 GRANT ... ON \*.\* TO ... 这样的语句。这类语句就代表了全局权限。

🔧 解决方案:如何限制用户只能看到授权的数据库?

想解决这个问题,核心思路就是移除用户多余的全局权限。

1. 方案一:移除SHOW DATABASES权限(推荐)

如果你只希望用户看不到其他数据库,但无需回收他的其他权限,可以只撤销 SHOW DATABASES 权限。在命令行中执行:

REVOKE SHOW DATABASES ON *.* FROM 'test'@'%';

2. 方案二:检查并回收不必要的全局权限

你也可以选择移除所有不必要的全局权限,仅保留数据库级别的授权。操作前请先查询并评估,再执行撤销:

-- 1. 查询当前权限以评估
SHOW GRANTS FOR 'test'@'%';
-- 2. 移除不必要的全局权限,例如:
REVOKE SELECT ON *.* FROM 'test'@'%';

3. 验证结果

执行权限回收后,可以让 test 重新登录并运行 SHOW DATABASES; 命令,检查数据库列表是否已符合预期。

💎 核心总结

理解权限层级是关键,MySQL 的这种设计是为了兼顾安全性与可用性:

  • 安全性优先:默认行为是“最小权限原则”,即用户只能看到自己有权限访问的数据。这有效防止了低权限用户通过 SHOW DATABASES 来探测服务器上的所有数据库名称,降低了信息泄露的风险。
  • 全局权限的双刃剑:作为最高层级的权限,全局权限能极大地方便管理员操作,但也会产生“看到所有数据库”的副作用。因此,在给普通业务账号授予任何全局权限时,都需格外谨慎。

到此这篇关于MySQL Workbench中的权限设置不生效的文章就介绍到这了,更多相关MySQL Workbench权限不生效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • CentOS下将MySQL 5.1升级到MySQL 5.5的步骤

    CentOS下将MySQL 5.1升级到MySQL 5.5的步骤

    这篇文章主要介绍了CentOS下将MySQL 5.1升级到MySQL 5.5的步骤,需要的朋友可以参考下
    2015-08-08
  • MySQL全局共享内存介绍

    MySQL全局共享内存介绍

    这篇文章主要介绍了MySQL全局共享内存介绍,全局共享内存则主要是 MySQL Instance(mysqld进程)以及底层存储引擎用来暂存各种全局运算及可共享的暂存信息,如存储查询缓存的 Query Cache,缓存连接线程的 Thread Cache等等,需要的朋友可以参考下
    2014-12-12
  • MySQL数据类型enum 枚举类型

    MySQL数据类型enum 枚举类型

    这篇文章主要介绍了MySQL数据类型enum 枚举类型,文章围绕主题展开详细的内容介绍,需要的小伙伴可以参考一下
    2022-06-06
  • 基于proxysql实现MySQL读写分离的实现实例

    基于proxysql实现MySQL读写分离的实现实例

    这篇文章主要介绍了基于proxysql实现MySQL读写分离,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-11-11
  • 解决MySQL因不能创建 PID 导致无法启动的方法

    解决MySQL因不能创建 PID 导致无法启动的方法

    这篇文章主要给大家介绍了关于解决MySQL因不能创建 PID 导致无法启动的方法,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面跟着小编一起来学习学习吧。
    2017-06-06
  • 如何避免mysql启动时错误及sock文件作用分析

    如何避免mysql启动时错误及sock文件作用分析

    这篇文章主要为大家介绍了在mysql启动过程中遇到错误时sock文件作用的分析详解,以及如何避免发生错误,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2022-01-01
  • MYSQL 数据库命名与设计规范

    MYSQL 数据库命名与设计规范

    对于MYSQL 数据库的命名与设计,需要一定的规范,所以我们要了解和快速的掌握mysql有很多的帮助。
    2008-12-12
  • mysql报错1267 - Illegal mix of collations问题的解决方法

    mysql报错1267 - Illegal mix of collations问题的解决方法

    这篇文章主要介绍了mysql报错1267 - Illegal mix of collations问题的解决方法,解决这个问题的方法是将两个字符集统一起来,文中介绍了好几种解决的办法,需要的朋友可以参考下
    2025-01-01
  • MySQL中的undo日志

    MySQL中的undo日志

    这篇文章主要介绍了MySQL中的undo日志的相关资料,帮助大家更好的理解和学习MySQL的相关知识,感兴趣的朋友可以了解下
    2020-11-11
  • mysql服务启动不了解决方案

    mysql服务启动不了解决方案

    最近在Windows 2003上的MySQL出现过多次正常运行时无法连接数据库故障,现象是无法连接数据库,也无法停止MySQL或重启MYSQL,由于每次都是草草尝试各种方法搞定即可本文将详细介绍解决方法
    2012-11-11

最新评论