错误1396 (HY000):操作创建用户失败'jack'@'

我似乎无法重新创建一个我已经删除的简单用户,即使是MySQL的根用户。

我的案例:用户'jack'之前存在,但我从mysql中删除了它。用户才能重新创建它。我在那张桌子上没看到这东西的痕迹。如果我对其他一些随机用户名执行这个命令,比如'jimmy',它就能正常工作(就像它最初对'jack'所做的那样)。

我做了什么破坏用户'jack',我如何撤销这个破坏,以重新创建'jack'作为MySQL安装的有效用户?

参见下面的示例。(当然,最初,jack这个词从被创造到被移除之间有很长一段时间。)

mysql> CREATE USER 'jack'@'localhost' IDENTIFIED BY 'test123';
Query OK, 0 rows affected (0.00 sec)


mysql> select user,host from user;
+------------------+-----------------+
| user             | host            |
+------------------+-----------------+
| root             | 127.0.0.1       |
| debian-sys-maint | localhost       |
| jack             | localhost       |
| root             | localhost       |
| root             | russ-elite-book |
+------------------+-----------------+
5 rows in set (0.00 sec)


mysql> delete from user where user = 'jack';
Query OK, 1 row affected (0.00 sec)


mysql> select user,host from user;
+------------------+-----------------+
| user             | host            |
+------------------+-----------------+
| root             | 127.0.0.1       |
| debian-sys-maint | localhost       |
| root             | localhost       |
| root             | russ-elite-book |
+------------------+-----------------+
4 rows in set (0.00 sec)


mysql> CREATE USER 'jack'@'localhost' IDENTIFIED BY 'test123';
ERROR 1396 (HY000): Operation CREATE USER failed for 'jack'@'localhost'
mysql> CREATE USER 'jimmy'@'localhost' IDENTIFIED BY 'test123';
Query OK, 0 rows affected (0.00 sec)


mysql> select user,host from user;
+------------------+-----------------+
| user             | host            |
+------------------+-----------------+
| root             | 127.0.0.1       |
| debian-sys-maint | localhost       |
| jimmy            | localhost       |
| root             | localhost       |
| root             | russ-elite-book |
+------------------+-----------------+
5 rows in set (0.00 sec)
808807 次浏览

尝试delete from mysql.db where user = 'jack',然后创建一个用户

尝试执行FLUSH PRIVILEGES;这个MySQL错误贴是关于错误代码的似乎报告了一些成功的情况下类似你的冲洗privs. 

您不应该以这种方式手动删除用户。MySQL有REVOKE语法用于删除特权,DROP USER语法用于删除特权:

REVOKE priv1,priv2,priv3,etc... FROM 'jack@localhost'; // remove certain privileges
DROP USER 'jack@localhost'; // completely delete the account

最好使用提供的工具,而不是在后台瞎忙活。

是的,这个bug就在那里。然而,我找到了一个小小的变通办法。

  • 假设用户在那里,那么删除用户
  • 删除用户后,需要刷新mysql权限
  • 现在创建用户。

这应该能解决问题。假设我们要创建admin @ localhost用户,下面的命令如下:

drop user admin@localhost;
flush privileges;
create user admin@localhost identified by 'admins_password'

干杯

如果要使用sql删除一个用户,需要删除以下表中的相关数据:columns_privdbprocs_privtables_priv。然后执行flush privileges;

删除用户,刷新权限;然后,创建用户。它确实有效!

two method
one :
setp 1: drop user 'jack'@'localhost';
setp 2: create user 'jack'@localhost identified by 'ddd';


two:
setp 1: delete from user where user='jack'and host='localhost';
setp 2: flush privileges;
setp 3: create user 'jack'@'localhost' identified by 'ddd';

自2007年以来,这个bug一直存在于bugs.mysql.com上,这个线程主要是在重复一年前的所有错误答案。

根据MySQL文档,像CREATE USERGRANTREVOKEDROP USER这样的命令不需要后续的FLUSH PRIVILEGES命令。原因很清楚,如果你读过文件的话。这是因为直接修改MySQL表不会将信息重新加载到内存中;然而,这个错误的大量解决方案声称FLUSH PRIVILEGES是答案。

这甚至可能不是一个bug。这是一个文档阴谋——不同版本的文档在一个关键的地方有所不同。

13.7.1.2. DROP USER语法

...

DROP USER USER [, USER]…

...

DROP USER 'jeffrey'@'localhost';

如果只指定帐户名的用户名部分,则使用'%'的主机名部分。

在MySQL 5.0.0中,DROP USER只删除没有特权的帐户。在MySQL 5.0.2中,它被修改为删除帐户特权。这意味着删除一个帐户的过程取决于你的MySQL版本。

从MySQL 5.0.2开始,你可以像下面这样删除一个帐户和它的特权:

DROP USER用户

该语句从所有授权表中删除该帐户的特权行。

我唯一一次得到这个错误是当我执行DROP USER user;就像文档建议的那样,但是MySQL不会将'%'作为通配符来处理,这样会删除所有主机上的所有用户。毕竟也没那么狂野。或者,当它删除本地主机用户,然后尝试删除位于%的用户时,它有时可能会工作。

我很清楚,当它试图删除%的用户时,它会发出错误消息并退出。在localhost上的后续CREATE USER将失败,因为localhost用户从未被删除。似乎没有必要像一位发帖者建议的那样,浪费时间在拨款表中寻找“幽灵”。

我看到7票赞成:

DROP USER 'jack@localhost';//完全删除帐户

它被解释为__abc0#错误

实际上似乎有一个真正的错误,产生相同的错误消息,但它与第一个创建的用户(在新的mysql服务器安装后)被删除有关。我不知道这个漏洞是否已经修复;但我不记得最近发生过这种事,我现在的体温达到了5.5.27。

MySQL服务器正在使用——skip-grant-tables选项运行,所以它不能执行这条语句

我知道这是旧的,但因为这是谷歌的第一个结果,我想我应该添加我的解决方案。在我的情况下,删除用户工作得很好,但重新创建用户给了我一个“错误2013 (HY000):在查询期间失去与MySQL服务器的连接”和“错误2006 (HY000): MySQL服务器已经离开”。我尝试了flush特权->删除用户解决方案,但仍然有相同的错误。

在我的情况下,这个错误是由于mysql从5.1升级到> 5.6。查看错误日志,我注意到它说要运行mysql_upgrade。这样做,我的创建用户语句工作良好!

这个帖子MySQL ERROR 1045 (28000): Access denied for user 'bill'@'(使用密码:YES)很有用。有时,会有匿名用户“@‘localhost’”或“@‘127.0.0.1’”。为了解决这个问题,

  1. 首先删除“创建用户”失败的用户。

  2. 创建新用户。

  3. 向新用户授予所需的特权。

  4. 冲洗的特权。

我有同样的错误。但是命令“FLUSH PRIVILEGES;”不起作用。 我这样做:

CREATE USER 'jimmy'@'localhost' IDENTIFIED BY 'test123';
UPDATE mysql.user SET USER='jack' WHERE USER='jimmy';

如果你在mysql.user表上使用DELETE语句试图删除一个用户,然后尝试用CREATE USER重新建立用户,你会得到一个1396错误。通过运行DROP USER 'username'@'host';来摆脱这个错误

DELETE
FROM mysql.user
WHERE user = 'jack';

(你会得到1396个错误,如果你试图重新创建杰克)

CREATE USER 'jack'@'localhost' IDENTIFIED BY PASSWORD '*Fi47ytFF3CD5B14E7EjkjkkC1D3F8086A5C0-krn';

(通过运行DROP USER来摆脱这种情况)

DROP USER 'jack'@'localhost';

(我想FLUSH PRIVILEGES不会有伤害,但肯定会先放弃用户。)

一个简单的工作围绕这个问题。由于“delete”命令只是删除mysql数据库“user”表中的用户记录,我们可以将其重新添加,然后完全删除该用户。然后可以创建同名用户。

步骤1。在mysql数据库中查找用户表的记录格式

use mysql;
select * from user;

步骤2。根据步骤1中显示的列,使用用户名创建一个虚拟记录。将其插入到表中,例如,提醒将“用户名”替换为您的用户名。

Insert into user value ('%','username','N','N','N','N','N',
'N','N','N','N','N','N','N','N','N','N','N','N','N','N','N',
'N','N','N','N','N','N','N','N','N','','','','','0','0','0',
'0','mysql_native_password',
'*52C5E3AC6BC5E2E0BFF86978BF62A1481AC79D58','N',
'2016-12-10 23:59:12',null,'N');

注意:有时您可能会在插入时遇到问题,只需更改数据即可使其工作。

步骤3。删除该用户。

drop user username;

现在您可以创建具有相同名称的用户。

只需从mysql.db中删除与用户相关的数据(也可以从其他表中删除),然后重新创建两者。

在MySQL 5.6中,使用Drop user userid;不起作用。使用:Drop user 'userid'@'localhost';和/或Drop user 'userid'@'%';。通过这种方式,我可以删除用户并重新创建它。

我最近得到了这个错误。

对我来说有用的是检查mysql工作台的“用户和特权”,并意识到user仍然存在。

从那里删除它之后,我就可以重新创建用户了。

我也遇到过同样的问题,经过几次搜索,我找到了一个适合我的解决方案。我希望它能帮助你。 因为你已经创建了用户,现在尝试在你的Mysql控制台中执行FLUSH PRIVILEGES。 __abc0你也可以检查这个。现在,在刷新之后,您可以创建一个新用户。

.使用实例
Step-1: Open terminal Ctrl+Alt+T
Step-2: mysql -u root -p  , it will ask for your MySQL password.

现在你可以看到Mysql控制台了。

Step-3: CREATE USER 'username'@'host' IDENTIFIED by 'PASSWORD';

而不是用户名,你可以输入你想要的用户名。如果你在你的本地机器上运行Mysql,那么输入“localhost"而不是主机,否则给出你想访问的服务器名。

实例:创建用户smruti@localhost由“hello”标识;

现在创建了新用户。如果你想给所有的访问然后键入

GRANT ALL PRIVILEGES ON * . * TO 'newuser'@'localhost';

现在你可以通过输入\q退出MySQL。现在再次登录

mysql -u newusername -p,然后按Enter。你可以看到一切。

希望这能有所帮助。

mysql> DELETE FROM mysql.db WHERE user = 'jack'

重启服务器:

# mysql.server restart

然后执行CREATE USER命令。

检查是否

“用户”@“%”

“用户”@“localhost”

有趣的是,MySQL工作台为我解决了这个问题。在Administration选项卡-> Users and Privileges中,列出了一个错误的用户。使用删除选项解决了这个问题。

我今天遇到了这个问题,我通过以下步骤解决了它:

1)手动插入麻烦的用户提供的值强制字段到mysql.user

mysql> insert into user(Host, User, Password, ssl_type)
values ('localhost', 'jack', 'jack', 'ANY');

2)

mysql> select * from user where User = 'jack';
1 row in set (0.00 sec)

3)。

mysql> drop user jack;
Query OK, 0 rows affected (0.00 sec)


B. mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)


C. mysql> create user 'jack' identified by 'jack';
Query OK, 0 rows affected (0.00 sec)


D. mysql> select Host, User, Password, ssl_type  from user where User = 'jack';
+-----------+-----------+-------------------------------------------+----------+
| Host      | User      | Password                                  | ssl_type |
+-----------+-----------+-------------------------------------------+----------+
| localhost | jack      | jack                                      | ANY      |
| %         | jack      | *45BB7035F11303D8F09B2877A00D2510DCE4D758 |          |
+-----------+-----------+-------------------------------------------+----------+
2 rows in set (0.00 sec)

4)。

mysql> delete from user
where User = 'nyse_user' and
Host = 'localhost' and
Password ='nyse';
Query OK, 1 row affected (0.00 sec)

B。

mysql> select Host, User, Password, ssl_type  from user where User = 'jack';
+------+-----------+-------------------------------------------+----------+
| Host | User      | Password                                  | ssl_type |
+------+-----------+-------------------------------------------+----------+
| %    | jack      | *45BB7035F11303D8F09B2877A00D2510DCE4D758 |          |
+------+-----------+-------------------------------------------+----------+
1 row in set (0.00 sec)

希望这能有所帮助。

似乎您需要为数据库创建用户,并为创建的用户授予特权

——比;为数据库创建用户

CREATE  USER <'username'>@'%'IDENTIFIED BY <'password'>;

创建用户“root”@“%”,用户名为“root”;

——比;授予的权限

FLUSH PRIVILEGES;
GRANT ALL PRIVILEGES ON <db name>.* TO '<username>'@'%';

授予mydb上的所有特权。*到“root”@“%”;

我和OP有同样的问题,接受的答案不适合我。在接受答案的评论中,@Rathish发布了一个对我有用的解决方案,我想引起大家的注意。

这是链接:

https://www.rathishkumar.in/2018/10/Error-1396-HY000-Operation-CREATE-DROP-USER-failed-for-user-host.html

Rathish的解决方案是撤销所有用户的访问权限:

REVOKE ALL ON *.* FROM 'user'@'host';
DROP USER 'user'@'host';
FLUSH PRIVILEGES;

他还很有帮助地指出,您可以通过选择“;user"和“;host"要确定是否有前一个操作留下的残留用户:

mysql.user: User accounts, global privileges, and other non-privilege columns
mysql.db: Database-level privileges
mysql.tables_priv: Table-level privileges
mysql.columns_priv: Column-level privileges
mysql.procs_priv: Stored procedure and function privileges
mysql.proxies_priv: Proxy-user privilege

谢谢你!

MySql的错误解决:错误码1396

  • 当你试图运行查询,创建一个用户如下所示。 <我> MySql>创建用户'springstudent'@'localhost' 授予*上的所有特权。* TO 'springstudent'@'localhost';
  • 但是,当你试图运行查询,创建用户在所有特权, 由于错误,它创建给予特权,而不显示用户 由于此问题,我们需要使用此脚本来刷新特权 <我> MySql>删除用户springstudent @ localhost 冲洗特权; 创建用户admin@localhost,密码为'admins_password'
  • 删除用户后,需要刷新mysql权限
  • 然后重新创建用户

Gotchaaa…… 解决了…

我的经验与这个错误导致我做显式删除mysql。用户,但不是从mysql.db

如果create中的用户名存在于user或db中,就会得到这个错误。通过做 从mysql删除。user == 'user@bar'; delete from mysql.db where User == 'user@bar'

将localhost替换为127.0.0.1

这对我很有用

步骤1)打开MySQL命令行客户端。

步骤2:select user, host from mysql.user;

步骤3)删除用户:drop user username@localhost;

步骤4)再次使用MySQL GUI创建用户。

步骤5)现在问题解决了。