5.7.7. 权限更改何时生效

本文详细介绍了MySQL中权限的生效机制,包括表、列和数据库权限的变化何时对客户端生效,以及全局权限和密码变更如何影响客户端连接。此外还讨论了如何通过GRANT、REVOKE等命令即时更新权限设置,并强调了手动修改授权表后需要执行特定命令才能使更改生效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当mysqld 启动时,所有授权表的内容被读进内存并且从此时生效。

当服务器注意到授权表被改变了时,现存的客户端连接有如下影响:

  • 表和列权限在客户端的下一次请求时生效。
  • 数据库权限改变在下一个USE db_name 命令生效。

·         全局权限的改变和密码改变在下一次客户端连接时生效。

如果用GRANT 、REVOKE 或SET PASSWORD 对授权表进行修改,服务器会注意到并立即重新将授权表载入内存。

如果你手动地修改授权表( 使用INSERT 、UPDATE 或DELETE 等 等) ,你应该执行mysqladmin flush-privileges mysqladmin reload 告诉服务器再装载授权表,否则你的更改将不会生效 ,除 非你重启服务器。

如果你直接更改了授权表但忘记重载,重启服务器后你的更改方生效。这样可能让你迷惑为什么你的更改没有什么变化!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值