sql >> Databasteknik >  >> RDS >> Mysql

Åtkomst nekad för användaren 'root'@'localhost' (med lösenord:JA) - Inga privilegier?

Om du har samma problem i MySql 5.7.+ :

Access denied for user 'root'@'localhost'

det beror på att MySql 5.7 som standard tillåter att ansluta med socket, vilket innebär att du bara ansluter med sudo mysql . Om du kör sql :

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

då ser du det :

+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

För att tillåta anslutning med root och lösenord, uppdatera sedan värdena i tabellen med kommandot :

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

Kör sedan kommandot select igen och du kommer att se att det har ändrats :

+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

Och det är allt. Du kan köra den här processen efter att ha kört och slutfört sudo mysql_secure_installation kommando.

För mariadb, använd

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

för att ställa in lösenord. Mer på https://mariadb.com/kb/en/set- lösenord/



  1. Skapa timer i Oracle Forms / Forms 6i och visa en klocka

  2. Metoder för att rangordna rader i SQL Server:ROW_NUMBER(), RANK(), DENSE_RANK() och NTILE()

  3. De vanligaste MySQL-frågorna

  4. Fönsterhantering i Oracle D2k Forms