解决mysql删除用户 bug的问题

 更新时间:2021年03月23日 14:39:56   作者:无霸独尊  
这篇文章主要介绍了解决mysql删除用户 bug的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

作者在使用mysql添加用户的时候,发现用户名给我写错了

强迫症的我,必须要改过来,但是发现删除用户的时候,命令是成功的

但是在此创建同名用户的时候,会报错,网上查了很多,说这是mysql的官方bug,不知道是作者水平不够没能理解到那个bug,还是真的解决了这个问题,下面和大家分享,欢迎大家一起讨论

删除了user的用户之后 无法再次创造相同的用户名

在mysql 数据库中有一张user表,可以查询到所有的用户和用户信息,删除里面的用户信息以及你赋予那个用户的什么权限就能完全的删除那个用户了

解决方法

注意这里多用户的权限进行了多次的删除之后,发现我创建的时候,这个用户的是% 允许远程连接的,所以最后一次删除成功了

刷新用户权限

FLUSH PRIVILEGES;

这个时候你再次创建同名的用户mysql 就不会报错了

补充:mysql 删除用户(两种实现方案)

drop

drop user XXX;删除已存在的用户,默认删除的是'XXX'@'%'这个用户,如果还有其他的用户如'XXX'@'localhost'等,不会一起被删除。如果要删除'XXX'@'localhost',使用drop删除时需要加上host即drop user 'XXX'@'localhost'。

delete

delete from user where user='XXX' and host='localhost';其中XXX为用户名,localhost为主机名。

区别

drop不仅会将user表中的数据删除,还会删除其他权限表的内容。而delete只删除user表中的内容,所以使用delete删除用户后需要执行FLUSH PRIVILEGES;刷新权限,否则下次使用create语句创建用户时会报错

补充:mysql创建用户报错[Err] 1396 - Operation CREATE USER failed for 'test'@'%'的解决方法

问题:

执行mysql创建用户语句CREATE USER test IDENTIFIED BY 'test'; 报错, 错误信息为

[Err] 1396 - Operation CREATE USER failed for 'test'@'%'

解决步骤:

1.创建过test用户。

2.查询后发现无此用户,则执行FLUSH PRIVILEGES;然后重新执行创建语句。

3.如果还是报错,则执行drop user 'test'@'%';然后重新执行创建语句。

4.创建成功。

可能原因:

1.用户已存在。

2.使用delete语句删除用户后没有刷新权限。

3.用户不存在,但是存在该用户的权限信息。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

相关文章

  • 详解关于MySQL 8.0走过的坑

    详解关于MySQL 8.0走过的坑

    这篇文章主要介绍了详解关于MySQL 8.0走过的坑,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • mysql不区分大小写配置小结

    mysql不区分大小写配置小结

    在某些情况下,我们可能希望数据库忽略大小写,以便更方便地进行操作,本文主要介绍了mysql不区分大小写配置,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MySQL表的创建及字段介绍(小白入门篇)

    MySQL表的创建及字段介绍(小白入门篇)

    这篇文章主要为大家介绍了MySQL表的创建及字段介绍(小白入门篇),有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • MySQL触发器的使用

    MySQL触发器的使用

    触发器用于在 MySQL 执行插入、更新或删除语句时,自动触发执行其他SQL代码。本文讲解触发器的正确使用方式
    2021-05-05
  • windows中同时安装两个不同版本的mysql数据库

    windows中同时安装两个不同版本的mysql数据库

    在项目中可能会用到多个版本的Mysql数据库,尤其是最常用的5版本的和8版本数据库,下面这篇文章主要给大家介绍了关于windows中同时安装两个不同版本的mysql数据库,需要的朋友可以参考下
    2024-03-03
  • Windows下mysql 8.0.11 安装教程

    Windows下mysql 8.0.11 安装教程

    这篇文章主要为大家详细介绍了Windows下mysql 8.0.11安装教程 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • MySQL中JSON_CONTAINS用法、语法、示例及其应用场景

    MySQL中JSON_CONTAINS用法、语法、示例及其应用场景

    这篇文章主要介绍了MySQL中JSON_CONTAINS用法、语法、示例及其应用场景的相关资料,JSON_CONTAINS函数用于检查JSON文档是否包含特定值或对象,这个函数非常适合于处理嵌套的JSON数据和灵活的查询需求,需要的朋友可以参考下
    2024-10-10
  • 浅谈SQLite时间函数的使用说明与总结分析

    浅谈SQLite时间函数的使用说明与总结分析

    本篇文章是对SQLite时间函数的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • windows 10下mysql 5.7.21 winx64安装配置方法图文教程

    windows 10下mysql 5.7.21 winx64安装配置方法图文教程

    这篇文章主要为大家详细介绍了windows 10下mysql 5.7.21 winx64安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • MySQL处理重复数据插入的处理方案

    MySQL处理重复数据插入的处理方案

    在数据库操作中,处理重复数据插入是一个常见的需求,特别是在批量插入数据时,可能会遇到主键冲突或唯一键冲突(Duplicate entry)的情况,本文将以一个实际的Python MySQL数据库操作为例,分析如何优化异常处理逻辑,需要的朋友可以参考下
    2025-04-04

最新评论