同样是删用户,为啥还有差别?

Posted 老叶茶馆_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了同样是删用户,为啥还有差别?相关的知识,希望对你有一定的参考价值。


* GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源

mysql当中,对于删除用户的操作大家并不陌生,先来看看问题:

# 创建用户testuser01
mysql> create user 'testuser01'@'%' identified by 'Test01.~!#';
Query OK, 0 rows affected (0.01 sec)
# 删除用户testuser01
mysql> drop user 'testuser01'@'%';
Query OK, 0 rows affected (0.01 sec)
# 再次创建testuser01成功
mysql> create user 'testuser01'@'%' identified by 'Test01.~!#';
Query OK, 0 rows affected (0.01 sec)

通过上面的例子发现,第一次创建用户testuser01之后,使用的drop的方式将用户删除,我们重新创建用户,正常创建用户成功,这时候大家会想这有啥问题吗?接着往下看:

# 再次删除用户testuser01
mysql> delete from mysql.user where user = 'testuser01';
Query OK, 1 row affected (0.01 sec)
# 再次创建testuser01用户失败
mysql> create user 'testuser01'@'%' identified by 'Test01.~!#';
ERROR 1396 (HY000): Operation CREATE USER failed for 'testuser01'@'%'

这时候我们使用delete的方式对用户进行了删除,发现删除后再次创建用户并没有成功,这个时候大家肯定会说用flush privileges啊,的确,这样又创建成功用户了。

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)
# 创建用户testuser01成功
mysql> create user 'testuser01'@'%' identified by 'Test01.~!#';
Query OK, 0 rows affected (0.01 sec)

那么,同样是删除,为什么前面drop操作以后,用户还可以重新创建?为什么delete操作却不可以,以及flush privileges是啥,究竟啥时候要用?带着这几个问题,我们进一步分析:

分析 

还是回到这条语句上,这条语句是创建一个用户'testuser01'@'%',在MySQL当中,这条语句在执行器执行时,大致上看成对mysql库的user表插入一条记录,既然是表,大可以先查查看:

mysql> select * from user where user = 'testuser01'\\G
*************************** 1. row ***************************
                    Host: %
                    User: testuser01
             Select_priv: N
             Insert_priv: N
               略
1 row in set (0.00 sec)

此时表中已然存在了该用户,但因为默认没有对该用户指定权限,所以下列对于权限描述的字段值都为N。另外会在内存里往对应的数组里插入一个用户的对象。我们知道MySQL的一个新的连接,会为新连接维护一个线程对象,然后从权限数组里查到这个用户的权限,为了获取该用户可完成的权限,还需要将权限值拷贝到这个线程对象中。回到前面的例子当中,delete操作相当于对这张表删除一条记录,当内存中并未删除,这也就为什么导致了delete操作后,无法重新创建的原因了,而drop操作是将表内记录和内存中的内容一并删除。

flush privileges是啥?

那么flush privileges究竟完成了什么呢?继续看:

session1session2
# root connect
create user 'testuser01'@'%' identified by 'Test01.~!#';

# testuser01 connect
delete from mysql.user where user = 'testuser01';

# testuser01 仍然处于连接
flush privileges

# testuser01 断开连接

我想现在答案已经很明显了,flush privileges 通常在使用了类似delete这样的操作的时候使用该语句,因为delete只是对表内数据进行了删除,但并未对内存进行更新,而flush privileges操作简单来说就是为了重新将数据加载进内存,达到数据的一致。因此,flush privileges什么时候使用也就清楚了。这里不多赘述了,内容如有不妥之处欢迎指正。

Enjoy GreatSQL :)


《深入浅出MGR》视频课程

戳此小程序即可直达B站

https://www.bilibili.com/medialist/play/1363850082?business=space_collection&business_id=343928&desc=0



文章推荐:


想看更多技术好文,点个“在看”吧!

以上是关于同样是删用户,为啥还有差别?的主要内容,如果未能解决你的问题,请参考以下文章

2022-03-30:有m个同样的苹果,认为苹果之间无差别, 有n个同样的盘子,认为盘子之间也无差别, 还有,比如5个苹果如果放进3个盘子, 那么131和113和311的放置方法,也认为是

微擎人人商城app上传图片删不掉,同样的后台,用苹果手机登录上传图片又可以删,用安卓手机就删不掉

如何给女朋友解释什么是删库跑路?

起跑:2019

为啥布尔值比字符消耗更多的内存?

windows与Linux操作系统的差别