Error 1396 hy000 operation alter user failed for zabbix

Learn how to fix MySQL ERROR code 1396 related to creating and removing users account

The MySQL ERROR 1396 occurs when MySQL failed in executing any statement related to user management, like CREATE USER or DROP USER statements.

This error frequently appears when you run statements to create or remove users from your MySQL database server.

MySQL has a bug that triggers this error when you remove a user without using the DROP USER statement.

This bug prevents you from re-creating a user previously deleted using the DELETE statement.

For example, suppose you create and then delete the developer account as shown below:

CREATE USER `developer` IDENTIFIED BY "developer";
DELETE FROM mysql.user WHERE user = 'developer';

Then the next time you create the user developer in your database server, you will trigger the error as follows:

mysql> DELETE FROM mysql.user WHERE user = 'developer';
Query OK, 1 row affected (0.00 sec)

mysql> CREATE USER `developer` IDENTIFIED BY "developer";
ERROR 1396 (HY000): Operation CREATE USER failed for 'developer'@'%'

To fix this, you need to run a DROP USER statement for the same user account.

MySQL will respond with the same error, but after that you can create the user again.

Take a look at the following example:

mysql> CREATE USER `developer` IDENTIFIED BY "developer";
ERROR 1396 (HY000): Operation CREATE USER failed for 'developer'@'%'

mysql> DROP USER `developer`;
ERROR 1396 (HY000): Operation DROP USER failed for 'developer'@'%'

mysql> CREATE USER `developer` IDENTIFIED BY "developer";
Query OK, 0 rows affected (0.01 sec)

Even though the DROP USER statement above throws an error, the same user can be created using the CREATE USER statement after that.

The error hasn’t been fixed up to MySQL version 8.0.26 as of today.

Other ways the error can be triggered

The error can also occur when you run the CREATE USER statement for an already existing user:

mysql> CREATE USER `developer` IDENTIFIED BY "developer";
Query OK, 0 rows affected (0.01 sec)

mysql> CREATE USER `developer` IDENTIFIED BY "developer";
ERROR 1396 (HY000): Operation CREATE USER failed for 'developer'@'%'

The same error could happen when you run the DROP USER or ALTER USER statement for a non-existing user account:

mysql> DROP USER `notuser`;
ERROR 1396 (HY000): Operation DROP USER failed for 'notuser'@'%'

mysql> ALTER USER dev@localhost IDENTIFIED BY 'newPassword';
ERROR 1396 (HY000): Operation ALTER USER failed for 'dev'@'localhost'

To list all existing users in your database server, you need to query the user table in your mysql database.

SELECT the user and host column from the table as follows:

SELECT user, host FROM mysql.user;

Please note that you may have different values between % and localhost in the host column.

Here’s an example from my database:

+------------------+-----------+
| user             | host      |
+------------------+-----------+
| developer        | %         |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
| nathan           | localhost |
| root             | localhost |
+------------------+-----------+

The % value in the host column is a wild card that allows the user account to connect from any host location.

The localhost value means that you need to connect from the localhost only.

MySQL treats two identical user account with different hosts value as different users.

When you don’t specify the host value in the CREATE USER statement, it will default to the % wild card.

-- Create developer@% account
CREATE USER `developer` IDENTIFIED BY "developer";

-- Create developer@localhost account
CREATE USER `developer`@localhost IDENTIFIED BY "developer";

The statements above will create two developer accounts with different hosts:

+------------------+-----------+
| user             | host      |
+------------------+-----------+
| developer        | %         |
| developer        | localhost |
+------------------+-----------+

When you trigger the ERROR 1396 that’s not caused by the bug above, be sure to check out the users you have in your database first.

Решение ошибки с кодом 1396 Error ‘Operation CREATE USER failed for… при настроенной репликации MySQL.

  • Ошибка возникает при ситуации, когда в схеме MasterSlave на мастере был создан пользователь и ему выданы некие права. Например, вот так:

CREATE USER 'zabbix'@'%' IDENTIFIED BY '<password>';
GRANT REPLICATION CLIENT,PROCESS,SHOW DATABASES,SHOW VIEW ON *.* TO 'zabbix'@'%';
  • После этого на слейве репликация останавливается с ошибкой:
Last_SQL_Errno: 1396
Last_SQL_Error: Error 'Operation CREATE USER failed for 'zabbix'@'%'' on query. Default database: ''. Query: 'CREATE USER 'zabbix'@'%' IDENTIFIED WITH 'mysql_native_password' AS '*B3198D30E7427FD4920A86A602DE74D9FABE22B9''

А причиной ошибки является то, что на slave-сервере, вероятнее всего, уже был такой пользователь, а потому репликация и прерывается. Такая особенность MySQL:

  • https://bugs.mysql.com/bug.php?id=28331
  • https://dba.stackexchange.com/questions/34940/adding-a-user-to-mysql-with-name-fails-with-error-1396

Решение проблемы логичное и простое: необходимо удалить пользователя на слейве, и самое главное – не забыть выполнить очистку прав, после чего запускать слейв:

delete from mysql.user where user='zabbix';
flush privileges;
start slave;

Либо же привести пользователя на слейве и мастере к единому виду, т.е. записи в таблицах должны совпадать, после чего также выполнить flush privileges; и запустить репликацию.

MySQL Connect database error:
1251 client does not support authentication protocol requested by server; consider upgrading Mysql client ERROR 1396 (HY000): Operation ALTER USER failed for ‘root’@’localhost’

Pre-registered mysql

mysql -u root -p

Input password

mysql> use mysql;
mysql> select user,host from user;

Note that my root and host are ‘%’
you may execute:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';

Change to:

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';

Operation record:

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';
ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'
mysql> use mysql;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select user,host from user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| root             | %         |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+
4 rows in set (0.00 sec)

mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
Query OK, 0 rows affected (0.00 sec)

mysql> quit
Bye

Read More:

Содержание

  1. How to fix MySQL ERROR 1396 — CREATE or DROP USER failed
  2. Other ways the error can be triggered
  3. Level up your programming skills
  4. About
  5. MySQL error code 1396 – Let’s solve it!
  6. What is the MySQL error code 1396?
  7. How we fix MySQL error 1396?
  8. Conclusion
  9. PREVENT YOUR SERVER FROM CRASHING!
  10. Technology blog by Rathish kumar
  11. [Solved] MySQL User Operation — ERROR 1396 (HY000): Operation CREATE / DROP USER failed for ‘user’@’host’
  12. 10 comments:
  13. MySQL: ERROR 1396 (HY000): Operation DROP USER failed for ‘username’
  14. ОШИБКА 1396 (HY000): сбой операции CREATE USER для ‘jack’ @ ‘localhost’
  15. 19 ответов

How to fix MySQL ERROR 1396 — CREATE or DROP USER failed

Posted on Oct 07, 2021

Learn how to fix MySQL ERROR code 1396 related to creating and removing users account

The MySQL ERROR 1396 occurs when MySQL failed in executing any statement related to user management, like CREATE USER or DROP USER statements.

This error frequently appears when you run statements to create or remove users from your MySQL database server.

MySQL has a bug that triggers this error when you remove a user without using the DROP USER statement.

This bug prevents you from re-creating a user previously deleted using the DELETE statement.

For example, suppose you create and then delete the developer account as shown below:

Then the next time you create the user developer in your database server, you will trigger the error as follows:

To fix this, you need to run a DROP USER statement for the same user account.

MySQL will respond with the same error, but after that you can create the user again.

Take a look at the following example:

Even though the DROP USER statement above throws an error, the same user can be created using the CREATE USER statement after that.

The error hasn’t been fixed up to MySQL version 8.0.26 as of today.

Other ways the error can be triggered

The error can also occur when you run the CREATE USER statement for an already existing user:

The same error could happen when you run the DROP USER or ALTER USER statement for a non-existing user account:

To list all existing users in your database server, you need to query the user table in your mysql database.

SELECT the user and host column from the table as follows:

Please note that you may have different values between % and localhost in the host column.

Here’s an example from my database:

The % value in the host column is a wild card that allows the user account to connect from any host location.

The localhost value means that you need to connect from the localhost only.

MySQL treats two identical user account with different hosts value as different users.

When you don’t specify the host value in the CREATE USER statement, it will default to the % wild card.

The statements above will create two developer accounts with different hosts:

When you trigger the ERROR 1396 that’s not caused by the bug above, be sure to check out the users you have in your database first.

Level up your programming skills

I’m sending out an occasional email with the latest programming tutorials. Drop your email in the box below and I’ll send new stuff straight into your inbox!

About

Nathan Sebhastian is a software engineer with a passion for writing tech tutorials.
Learn JavaScript and other web development technology concepts through easy-to-understand explanations written in plain English.

Источник

MySQL error code 1396 – Let’s solve it!

Do you have trouble adding MySQL database users?

Often MySQL error code 1396 pops up when we try to create a user that already exists.

At Bobcares, we often receive requests to solve such Database errors as part of our Server Management Services.

Today we will discuss MySQL error code 1396 in detail and see how our Support Engineers fix this error for our customers.

What is the MySQL error code 1396?

All databases should have valid users that have privileges to do database queries as well as edits.

Unfortunately, errors are common while querying in the MySQL databases. MySQL error code 1396 is often related to website restore, migration, etc. In such scenarios, this error occurs when we try to create an already existing user in MySQL.

Similarly, we often see this error even if we delete the already existing user too.

A typical error message when adding MySQL user appears as:

How we fix MySQL error 1396?

We now know the scenario that causes MySQL error 1396. Let’s see how our Support Engineers fix this error.

Recently, one of our customers got MySQL error 1396 while trying to create a new user. He checked and found that the user already existed in the database. So, he deleted the user and tried creating the user once again.

But unfortunately, he received the same error.

Here, our Support Engineers started troubleshooting by checking all occurrences of the database user in MySQL table.

We used the command:

There was a user with the same name and this was creating problems while new user creation. Here, the customer was trying to delete the user using the command DROP user username . In MySQL, if you specify only the user name part of the account name, it uses a hostname part of ‘%’. This stopped removing the correct user.

Therefore, we had to remove the exact MySQL user using:

Further, we used the FLUSH PRIVILEGEs command to remove all the caches. FLUSH PRIVILEGE operation will make the server reload the grant tables.

So, we executed the following query and created the newuser ‘user’ successfully.

This resolved the error effectively.

[Need help to solve MySQL error code 1396?- We’ll help you.]

Conclusion

In short, the MySQL error 1396 occurs when we try to create a user that already exists in the database. Today’s write-up also discussed the various causes of this error and saw how our Support Engineers fixed it for our customers.

PREVENT YOUR SERVER FROM CRASHING!

Never again lose customers to poor server speed! Let us help you.

Our server experts will monitor & maintain your server 24/7 so that it remains lightning fast and secure.

Источник

Technology blog by Rathish kumar

[Solved] MySQL User Operation — ERROR 1396 (HY000): Operation CREATE / DROP USER failed for ‘user’@’host’

REAL AND GENUINE ONLINE LOVE SPELL CASTER TO BRING EX LOVER URGENTLY CALL OR WHATSAPP +2348118829899.

I want to use this opportunity I have to say a big thanks to Dr Great for getting back my ex husband. I’m Linda Gibson from USA, after 7 years of marriage my husband left me for another woman I did whatever I could to get him back but all I did was in vain I was sad, but I didn’t lose hope of getting him back because I had faith in God. So I search online on how to get my husband back, and I came across a post of Dr Great of how he helped a lady to get back her ex, I contacted him and told him the pain I was going through, he told me what to do and I did it, then he casted a love spell for me 48 hours later my husband called me and told me he is sorry for what he did and that he misses me very much, later that day he came back home and beg for my forgiveness, since then our love grew stronger. For the marvelous things Dr Great has done for me it would be unfair for me not to let the whole world know that such a powerful spell caster do live. If you want to get back your ex fast email Dr Great at infinitylovespell@gmail.com or infinitylovespell@yahoo.com or add him up on WhatsApp +2348118829899 Blog: lindagibson90.blogspot.com view his blog http://infinitylovespell1.blogspot.com

REAL AND GENUINE ONLINE LOVE SPELL CASTER TO BRING EX LOVER URGENTLY CALL OR WHATSAPP +2348118829899.

Источник

MySQL: ERROR 1396 (HY000): Operation DROP USER failed for ‘username’

При удалении пользователя MySQL сообщает об ошибке:

mysql> drop user usertest;
ERROR 1396 (HY000): Operation DROP USER failed for ‘usertest’@’%’

Хотя пользователь вроде есть:

Проверяем права пользователя:

mysql> show grants for ‘usertest’@’%’;
ERROR 1141 (42000): There is no such grant defined for user ‘usertest’ on host ‘%’

При выборке надо добавлять поле Host:

mysql> select User, Host from mysql.user where user like ‘usertest’;
+———+————+
| User | Host |
+———+————+
| usertest| localhost |
+———+————+
1 row in set (0.00 sec)

И теперь удаляем:

mysql> drop user ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

Если имя было указано верно, но данный способ не помог, то проверьте активность сессий пользователя:

Остановите процесс, если такой есть:

mysql> kill номер процесса;
Query OK, 0 rows affected (0.01 sec)

После того, как остановили процесс – отзовите права пользователя на базу:

mysql> revoke all privileges on usertestdb.* from ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

И после этого попробуйте удалить пользователя:

mysql> drop user ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

Источник

ОШИБКА 1396 (HY000): сбой операции CREATE USER для ‘jack’ @ ‘localhost’

Кажется, я не могу воссоздать простого пользователя, которого я удалил, даже как root в MySQL.

Мой случай: пользовательский «jack» существовал раньше, но я удалил его из mysql.user, чтобы его воссоздать. Я не вижу пережитков этого в этой таблице. Если я выполню эту команду для какого-то другого случайного имени пользователя, скажем, «jimmy», он отлично работает (как это первоначально делалось для «jack» ).

Что я сделал, чтобы повредить «гнездо пользователя» и как я могу отменить это повреждение, чтобы воссоздать «джек» в качестве допустимого пользователя для этой установки MySQL?

См. пример ниже. (Конечно, изначально было много времени между созданием «джек» и его удалением.)

19 ответов

Попробуйте выполнить FLUSH PRIVILEGES . Это сообщение об ошибке MySQL в этом коде ошибки сообщает о некотором успехе в случае, аналогичном вашему, после промывки привилегий.

Да, эта ошибка существует. Однако я нашел небольшое обходное решение.

  • Предположим, что пользователь существует, поэтому отпустите
  • После удаления пользователя необходимо сбросить привилегии mysql
  • Теперь создайте пользователя.

Это должно решить. Предполагая, что мы хотим создать user admin @localhost, это были бы команды:

Этот баг сидит на bugs.mysql.com с 2007 года, и этот поток в основном просто распутывает все эти неправильные ответы даже до года назад.

Согласно документации MySQL, команды типа CREATE USER , GRANT , REVOKE и DROP USER не требуют последующей команды FLUSH PRIVILEGES . Понятно, почему, если читать документы. Это потому, что изменение таблиц MySQL напрямую не перезагружает информацию в память; однако множество решений этой ошибки утверждают, что FLUSH PRIVILEGES является ответом.

Это тоже не может быть ошибкой. Это заговор документации — документы меняются в одном критическом месте от версии к версии.

13.7.1.2. Синтаксис DROP USER

Пользователь DROP USER [, пользователь].

Если вы укажете только имя имени пользователя в имени учетной записи, используется часть имени узла «%».

DROP USER , как представлено в MySQL 5.0.0, удаляет только учетные записи, которые не имеют никаких прав. В MySQL 5.0.2 он был изменен для удаления привилегий учетной записи. Это означает, что процедура удаления учетной записи зависит от вашей версии MySQL.

Начиная с MySQL 5.0.2 вы можете удалить учетную запись и ее привилегии следующим образом:

Оператор удаляет строки привилегий для учетной записи из всех таблиц предоставления.

Единственный раз, когда я получаю эту ошибку, когда я делаю DROP USER user ; как и в документе, но MySQL не рассматривает «%» как шаблон, чтобы удалить всех пользователей на всех хостах. В конце концов, это не так дико. Или, может быть, иногда он работает, когда он удаляет пользователя localhost, а затем пытается удалить его на%.

Мне ясно, что когда он пытается удалить пользователя в%, он выдает сообщение об ошибке и завершает работу. Последующий CREATE USER на localhost не сработает, потому что пользователь localhost не был удален. Кажется, нет необходимости тратить время на рытье в таблицах грантов, ищущих призраков, как предлагал один плакат.

Я вижу 7 голосов за:

DROP USER ‘jack @localhost’;//полностью удалить учетную запись

Что интерпретируется как DROP USER ‘[email protected]’@’%’; # wrong

На самом деле существует реальная ошибка, которая генерирует одно и то же сообщение об ошибке, но она связана с первым созданным пользователем (после установки нового сервера mysql). Исправлена ​​ли эта ошибка, я не знаю; но я не помню, что это произошло в последнее время, и я в настоящее время готов к версии 5.5.27.

Источник

Я пытаюсь создать нового пользователя в MySQL,

    create user 'saravanakumar'@'localhost' identified by 'saravanakumar';

он показывает ошибку, как,

    ERROR 1396 (HY000): Operation CREATE USER failed for 'saravanakumar'@'localhost'

после того как я прочитал этот

ошибка 1396 (HY000): не удалось создать пользователя для «jack» @ «localhost»

удалить пользователя.Но я не могу.Это показывает

    mysql> SELECT User FROM mysql.user;
    +---------------+
    | User          |
    +---------------+
    | root          |
    | saravanakumar |
    | saravanakumar |
    |               |
    | root          |
    | saravanakumar |
    |               |
    | root          |
    +---------------+
    8 rows in set (0.00 sec)

    mysql> FLUSH PRIVILEGES;
    Query OK, 0 rows affected (0.00 sec)

    mysql> SELECT User FROM mysql.user;
    +---------------+
    | User          |
    +---------------+
    | root          |
    | saravanakumar |
    | saravanakumar |
    |               |
    | root          |
    | saravanakumar |
    |               |
    | root          |
    +---------------+
    8 rows in set (0.00 sec)

как я могу удалить все данные пользователя в таблице и как я могу создать одного пользователя.В чем коренная причина этой проблемы? эксперты, пожалуйста, помогите мне.

3 ответов


ERROR 1396 (HY000): Operation CREATE USER failed for 'saravanakumar'@'localhost'

действительно указано, что пользователь уже существует или существовало.

FLUSH привилегии не удаляет пользователей.

Reloads the privileges from the grant tables in the mysql database.

The server caches information in memory as a result of GRANT, CREATE USER, 
CREATE SERVER, and INSTALL PLUGIN statements. This memory is not released 
by the corresponding REVOKE, DROP USER, DROP SERVER, and UNINSTALL PLUGIN 
statements, so for a server that executes many instances of the statements 
that cause caching, there will be an increase in memory use. 
This cached memory can be freed with FLUSH PRIVILEGES.

вы ищете падение пользователя.

DROP USER user [, user] ...

http://dev.mysql.com/doc/refman/5.1/en/drop-user.html


порядок работы будет:

DROP USER 'saravanakumar'@HOSTNAME;
CREATE USER 'saravanakumar'@HOSTNAME [IDENTIFIED BY 'password'];

вам, вероятно, потребуется очистить привилегии, если вы используете delete from (не).
помните: это не обязательно отменять все привилегии, которые может иметь этот пользователь (например, привилегии таблицы), вам придется сделать это самостоятельно — если вы этого не сделаете, вы не сможете воссоздать пользователя.

REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'saravanakumar'@HOSTNAME;
DELETE FROM mysql.user WHERE user='saravanakumar';
FLUSH PRIVILEGES;
CREATE USER 'saravanakumar'@HOSTNAME [IDENTIFIED BY 'password'];

«пользователь» необходимо указать имя учетной записи

Syntax for account names is 'user_name'@'host_name'

и

An account name consisting only of a user name is equivalent 
to 'user_name'@'%'. For example, 'me' is equivalent to 'me'@'%'.

дополнительное чтение:http://dev.mysql.com/doc/refman/5.1/en/account-names.html


пожалуйста, прочитайте эти сообщения об ошибках для дальнейшего разъяснения

http://bugs.mysql.com/bug.php?id=28331

http://bugs.mysql.com/bug.php?id=62255


Мне работает, я устанавливаю имя хоста в верхнем регистре:

пользователем капля »@’localhost’а


select User, Host from mysql.user;

дал мне понять, что происходит. Я оказался с одним и тем же пользователем под несколькими хостами. Удалив ненужные помогли!


How to fix MySQL ERROR 1396 — CREATE or DROP USER failed

Posted on Oct 07, 2021

Learn how to fix MySQL ERROR code 1396 related to creating and removing users account

The MySQL ERROR 1396 occurs when MySQL failed in executing any statement related to user management, like CREATE USER or DROP USER statements.

This error frequently appears when you run statements to create or remove users from your MySQL database server.

MySQL has a bug that triggers this error when you remove a user without using the DROP USER statement.

This bug prevents you from re-creating a user previously deleted using the DELETE statement.

For example, suppose you create and then delete the developer account as shown below:

Then the next time you create the user developer in your database server, you will trigger the error as follows:

To fix this, you need to run a DROP USER statement for the same user account.

MySQL will respond with the same error, but after that you can create the user again.

Take a look at the following example:

Even though the DROP USER statement above throws an error, the same user can be created using the CREATE USER statement after that.

The error hasn’t been fixed up to MySQL version 8.0.26 as of today.

Other ways the error can be triggered

The error can also occur when you run the CREATE USER statement for an already existing user:

The same error could happen when you run the DROP USER or ALTER USER statement for a non-existing user account:

To list all existing users in your database server, you need to query the user table in your mysql database.

SELECT the user and host column from the table as follows:

Please note that you may have different values between % and localhost in the host column.

Here’s an example from my database:

The % value in the host column is a wild card that allows the user account to connect from any host location.

The localhost value means that you need to connect from the localhost only.

MySQL treats two identical user account with different hosts value as different users.

When you don’t specify the host value in the CREATE USER statement, it will default to the % wild card.

The statements above will create two developer accounts with different hosts:

When you trigger the ERROR 1396 that’s not caused by the bug above, be sure to check out the users you have in your database first.

Level up your programming skills

I’m sending out an occasional email with the latest programming tutorials. Drop your email in the box below and I’ll send new stuff straight into your inbox!

About

Nathan Sebhastian is a software engineer with a passion for writing tech tutorials.
Learn JavaScript and other web development technology concepts through easy-to-understand explanations written in plain English.

Источник

MySQL error code 1396 – Let’s solve it!

Do you have trouble adding MySQL database users?

Often MySQL error code 1396 pops up when we try to create a user that already exists.

At Bobcares, we often receive requests to solve such Database errors as part of our Server Management Services.

Today we will discuss MySQL error code 1396 in detail and see how our Support Engineers fix this error for our customers.

What is the MySQL error code 1396?

All databases should have valid users that have privileges to do database queries as well as edits.

Unfortunately, errors are common while querying in the MySQL databases. MySQL error code 1396 is often related to website restore, migration, etc. In such scenarios, this error occurs when we try to create an already existing user in MySQL.

Similarly, we often see this error even if we delete the already existing user too.

A typical error message when adding MySQL user appears as:

How we fix MySQL error 1396?

We now know the scenario that causes MySQL error 1396. Let’s see how our Support Engineers fix this error.

Recently, one of our customers got MySQL error 1396 while trying to create a new user. He checked and found that the user already existed in the database. So, he deleted the user and tried creating the user once again.

But unfortunately, he received the same error.

Here, our Support Engineers started troubleshooting by checking all occurrences of the database user in MySQL table.

We used the command:

There was a user with the same name and this was creating problems while new user creation. Here, the customer was trying to delete the user using the command DROP user username . In MySQL, if you specify only the user name part of the account name, it uses a hostname part of ‘%’. This stopped removing the correct user.

Therefore, we had to remove the exact MySQL user using:

Further, we used the FLUSH PRIVILEGEs command to remove all the caches. FLUSH PRIVILEGE operation will make the server reload the grant tables.

So, we executed the following query and created the newuser ‘user’ successfully.

This resolved the error effectively.

[Need help to solve MySQL error code 1396?- We’ll help you.]

Conclusion

In short, the MySQL error 1396 occurs when we try to create a user that already exists in the database. Today’s write-up also discussed the various causes of this error and saw how our Support Engineers fixed it for our customers.

PREVENT YOUR SERVER FROM CRASHING!

Never again lose customers to poor server speed! Let us help you.

Our server experts will monitor & maintain your server 24/7 so that it remains lightning fast and secure.

Источник

Technology blog by Rathish kumar

[Solved] MySQL User Operation — ERROR 1396 (HY000): Operation CREATE / DROP USER failed for ‘user’@’host’

10 comments:

REAL AND GENUINE ONLINE LOVE SPELL CASTER TO BRING EX LOVER URGENTLY CALL OR WHATSAPP +2348118829899.

I want to use this opportunity I have to say a big thanks to Dr Great for getting back my ex husband. I’m Linda Gibson from USA, after 7 years of marriage my husband left me for another woman I did whatever I could to get him back but all I did was in vain I was sad, but I didn’t lose hope of getting him back because I had faith in God. So I search online on how to get my husband back, and I came across a post of Dr Great of how he helped a lady to get back her ex, I contacted him and told him the pain I was going through, he told me what to do and I did it, then he casted a love spell for me 48 hours later my husband called me and told me he is sorry for what he did and that he misses me very much, later that day he came back home and beg for my forgiveness, since then our love grew stronger. For the marvelous things Dr Great has done for me it would be unfair for me not to let the whole world know that such a powerful spell caster do live. If you want to get back your ex fast email Dr Great at infinitylovespell@gmail.com or infinitylovespell@yahoo.com or add him up on WhatsApp +2348118829899 Blog: lindagibson90.blogspot.com view his blog http://infinitylovespell1.blogspot.com

REAL AND GENUINE ONLINE LOVE SPELL CASTER TO BRING EX LOVER URGENTLY CALL OR WHATSAPP +2348118829899.

Источник

ERROR 1396 (HY000): Operation CREATE USER failed for ‘root’@’%’ #129

Comments

innovia commented Jan 7, 2016

we are struggling to figure this one out

it does not work out of the box — running on OSX

everytime we attempt to start it it fails after intializing the db but when we run it a 2nd time mysql runs becuas ethe DATA_DIR folder already exists

why does it keep failing?

running version 5.6.28 of mysql WITHOUT MODIFICATIONS!

also worth mentioning we see the issue only with docker-compose,

seems like the root user is the one being used to log in to mysql and then attempt to create it while logged in as root fails

The text was updated successfully, but these errors were encountered:

yosifkit commented Jan 8, 2016

I assume this is the entrypoint script in the mysql image that is failing.

It is the usual way to modify the root user in sql while being the root user and works fine without docker-compose . What does your yaml have configured for the mysql container?

Ninir commented Feb 1, 2016

@yosifkit I assume @innovia has this kind of configuration:

It is also failing for me, but running docker-compose up again makes it. This seems logical as we try to create another root user.

jlaswell commented Feb 1, 2016

@Ninir I’m seeing the same for a fresh docker-compose up on Ubuntu 14.04 for the :5.6 tag, and it also works after re-running another docker-compose up . It only seems to fail any time after rm ing the container, so it seems to be limited to initial creation.

yosifkit commented Feb 1, 2016

@Ninir, the entrypoint script would fail to work if you set MYSQL_USER to root ; specifically line #75 will fail to create the second user ‘root’@’%’ since it will already exist in the users table from above. If you want to use root as your user, you only need to set MYSQL_ROOT_PASSWORD .

Ninir commented Feb 2, 2016

@yosifkit I know, was just Reproducing @innovia s case 🙂

ababushkin commented Sep 1, 2016

Anyone found a solution to this problem yet? I’ve had to switch to MariaDB for the time being.

Ninir commented Sep 1, 2016

@ababushkin One solution was suggested, which is about only setting the MYSQL_ROOT_PASSWORD env var. Are you having another issues?

ababushkin commented Sep 2, 2016

@Ninir sorry I didn’t realise that was the suggested solution — I skimmed past @yosifkit post 🙂

Trying that worked for me.

yosifkit commented Sep 2, 2016

As far as I can tell, the original issue seems solved and has helped others. Closing.

karthik-aiyer-fujixerox commented Mar 15, 2017

@yosifkit I encountered the same problem and tried the suggested solution but doesn’t seem to be working for me.
Running attached docker file with following command still gives me the error mentioned in attached docker_log.txt

Command:
docker build —build-arg http_proxy= —build-arg https_proxy= -f mySQL_Dockerfile -t mysql .

karthik-aiyer-fujixerox commented Mar 15, 2017

Turns out this solution doesn’t work on the «mysql:latest» image. It works fine on «mysql:5.7» image.

ltangvald commented Mar 15, 2017

That is very odd. They are just two different tags for the same image. Both your mysql:latest and mysql:5.7 are updated?

ltangvald commented Mar 15, 2017

Have you tried deleting your built image to ensure it’s rebuilt from scratch? At least in earlier Docker versions I occasionally had issues where changes in the Dockerfile didn’t always make the affected layer rebuild properly.

helsont commented Mar 15, 2018

Hi, is it possible to add a warning log when you specify MYSQL_USER: root ? I was wrangling with this bug for days before I found this thread. Think it might be useful to add a heads up for people in the future. I don’t see this anywhere in the documentation, either. At minimum a note in the docs would be helpful.

This comment has been minimized.

Footer

© 2023 GitHub, Inc.

You can’t perform that action at this time.

You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session.

Источник

MySQL: ERROR 1396 (HY000): Operation DROP USER failed for ‘username’

При удалении пользователя MySQL сообщает об ошибке:

mysql> drop user usertest;
ERROR 1396 (HY000): Operation DROP USER failed for ‘usertest’@’%’

Хотя пользователь вроде есть:

Проверяем права пользователя:

mysql> show grants for ‘usertest’@’%’;
ERROR 1141 (42000): There is no such grant defined for user ‘usertest’ on host ‘%’

При выборке надо добавлять поле Host:

mysql> select User, Host from mysql.user where user like ‘usertest’;
+———+————+
| User | Host |
+———+————+
| usertest| localhost |
+———+————+
1 row in set (0.00 sec)

И теперь удаляем:

mysql> drop user ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

Если имя было указано верно, но данный способ не помог, то проверьте активность сессий пользователя:

Остановите процесс, если такой есть:

mysql> kill номер процесса;
Query OK, 0 rows affected (0.01 sec)

После того, как остановили процесс – отзовите права пользователя на базу:

mysql> revoke all privileges on usertestdb.* from ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

И после этого попробуйте удалить пользователя:

mysql> drop user ‘usertest’@’localhost’;
Query OK, 0 rows affected (0.00 sec)

Источник

Понравилась статья? Поделить с друзьями:
  • Error 1392 при установке windows
  • Error 1381 hy000 you are not using binary logging
  • Error 138 wow
  • Error 138 world of warcraft
  • Error 138 warface