Mysql
 sql >> Database >  >> RDS >> Mysql

Accesso negato per l'utente 'root'@'localhost' (usando la password:SÌ) - Nessun privilegio?

Se hai lo stesso problema in MySql 5.7.+ :

Access denied for user 'root'@'localhost'

è perché MySql 5.7 per impostazione predefinita consente di connettersi con socket, il che significa che ti connetti solo con sudo mysql . Se esegui sql :

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

allora lo vedrai :

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

Per consentire la connessione con root e password, aggiorna i valori nella tabella con il comando :

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

Quindi esegui di nuovo il comando select e vedrai che è cambiato:

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

E questo è tutto. Puoi eseguire questo processo dopo aver eseguito e completato sudo mysql_secure_installation comando.

Per mariadb, usa

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

per impostare la password. Maggiori informazioni su https://mariadb.com/kb/en/set- password/