MySQL grant之后是否需要flush privileges

MySQL中,使用grant进行权限分配或revoke进行权限撤销时,通常不需要执行flush privileges以使改动生效。直接修改系统表则需要flush privileges以更新内存中的权限信息。全局权限仅对新连接生效,已存在的会话不受影响,而表权限和列权限的更改对现有会话立即生效。
摘要由CSDN通过智能技术生成

MySQL grant之后是否需要flush privileges

在MySQL旧版本的使用上,很多人习惯直接更新mysql.user等表来完成用户的修改密码,修改权限等,最后需要flush privileges来生效。
而使用grant来授权或revoke来收权,是不需要执行flush privileges的。
直接修改系统表的方式之所以需要flush privileges,是改了系统表之后,内存里的权限信息并没有同步更新,所以需要将内存的权限信息flush,然后重新加载磁盘里的最新权限信息。
而grant/revoke,是自动完成更新系统表和重新加载内存权限信息。

虽然grant/revoke不需要flush privileges,但针对已存在的连接,还是有一些不生效的情况。
1.全局权限
全局权限即授权对象是grant … on *.*,例如all privileges,super等。
全局权限对于已存在的会话,只会在登陆之初获取一次权限信息,之后执行的grant和revoke,只对新连接的会话生效,而对已存在会话不生效。
会话1,给test@’%'授予all privileges全局权限

mysql> show grants for test@'%';
+----------------------------------+
| Grants for test@%                |
+----------------------------------+
| GRANT USAGE ON *.* TO 'test'@'%' |
+----------------------------------+
1 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值