如何通过MySQL为特定数据表设置精确的操作权限?

2026-05-03 07:000阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计888个文字,预计阅读时间需要4分钟。

如何通过MySQL为特定数据表设置精确的操作权限?

MySQL中设置表级权限时,必须明确指定数据库名和表名,不能仅仅写表名。正确格式为:

正确写法是:GRANT SELECT, INSERT ON mydb.users TO 'alice'@'localhost';

  • 必须带数据库前缀,GRANT SELECT ON users TO ... 是无效的,MySQL 会报错 ERROR 1144 (42000): Illegal GRANT/REVOKE command
  • 支持通配符但仅限表名:mydb.`log_%` 可以匹配 log_2024log_errors,但 `mydb`.* 是库级,不是表级
  • 如果用户尚不存在,GRANT 不会自动创建用户;得先 CREATE USER 或用 GRANT ... IDENTIFIED BY(5.7+ 已弃用该用法)

REVOKE 后权限没立刻失效?检查 FLUSH PRIVILEGES

执行 REVOKE 后某些客户端仍能操作旧权限,不是 bug,而是权限缓存没刷新。

MySQL 权限变更后,已连接的客户端会继续使用内存中的权限副本,直到重连或手动刷新。

阅读全文
标签:Mysql

本文共计888个文字,预计阅读时间需要4分钟。

如何通过MySQL为特定数据表设置精确的操作权限?

MySQL中设置表级权限时,必须明确指定数据库名和表名,不能仅仅写表名。正确格式为:

正确写法是:GRANT SELECT, INSERT ON mydb.users TO 'alice'@'localhost';

  • 必须带数据库前缀,GRANT SELECT ON users TO ... 是无效的,MySQL 会报错 ERROR 1144 (42000): Illegal GRANT/REVOKE command
  • 支持通配符但仅限表名:mydb.`log_%` 可以匹配 log_2024log_errors,但 `mydb`.* 是库级,不是表级
  • 如果用户尚不存在,GRANT 不会自动创建用户;得先 CREATE USER 或用 GRANT ... IDENTIFIED BY(5.7+ 已弃用该用法)

REVOKE 后权限没立刻失效?检查 FLUSH PRIVILEGES

执行 REVOKE 后某些客户端仍能操作旧权限,不是 bug,而是权限缓存没刷新。

MySQL 权限变更后,已连接的客户端会继续使用内存中的权限副本,直到重连或手动刷新。

阅读全文
标签:Mysql