sql >> Databáze >  >> RDS >> Mysql

Přístup odepřen pro uživatele 'root'@'localhost' (s použitím hesla:ANO) - Žádná oprávnění?

Pokud máte stejný problém v MySql 5.7.+:

Access denied for user 'root'@'localhost'

je to proto, že MySql 5.7 ve výchozím nastavení umožňuje připojení se socketem, což znamená, že se stačí připojit pomocí sudo mysql . Pokud spustíte sql :

SELECT user,authentication_string,plugin,host FROM mysql.user;

pak to uvidíte :

+------------------+-------------------------------------------+-----------------------+-----------+
| user             | authentication_string                     | plugin                | host      |
+------------------+-------------------------------------------+-----------------------+-----------+
| root             |                                           | auth_socket           | localhost |
| mysql.session    | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| mysql.sys        | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| debian-sys-maint | *497C3D7B50479A812B89CD12EC3EDA6C0CB686F0 | mysql_native_password | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
4 rows in set (0.00 sec)

Chcete-li povolit připojení s rootem a heslem, aktualizujte hodnoty v tabulce příkazem :

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Current-Root-Password';
FLUSH PRIVILEGES;

Poté znovu spusťte příkaz select a uvidíte, že se změnil:

+------------------+-------------------------------------------+-----------------------+-----------+
| user             | authentication_string                     | plugin                | host      |
+------------------+-------------------------------------------+-----------------------+-----------+
| root             | *2F2377C1BC54BE827DC8A4EE051CBD57490FB8C6 | mysql_native_password | localhost |
| mysql.session    | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| mysql.sys        | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
| debian-sys-maint | *497C3D7B50479A812B89CD12EC3EDA6C0CB686F0 | mysql_native_password | localhost |
+------------------+-------------------------------------------+-----------------------+-----------+
4 rows in set (0.00 sec)

A to je vše. Tento proces můžete spustit po spuštění a dokončení sudo mysql_secure_installation příkaz.

Pro mariadb použijte

SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');

nastavit heslo. Více na https://mariadb.com/kb/en/set- heslo/



  1. Jak zastavit/zabít dotaz v postgresql?

  2. Jak uniknout znaku otazníku (?) pomocí Spring JpaRepository

  3. Oracle-XMLTYPE :Jak aktualizovat hodnotu

  4. Jak importovat a exportovat databázi přes phpMyAdmin (chyba 'Přístup odepřen vytvořit databázi db_name')