Mysql
 sql >> Base de données >  >> RDS >> Mysql

Accès refusé pour l'utilisateur 'root'@'localhost' (en utilisant le mot de passe :OUI) - Pas de privilèges ?

Si vous avez le même problème dans MySql 5.7.+ :

Access denied for user 'root'@'localhost'

c'est parce que MySql 5.7 permet par défaut de se connecter avec socket, ce qui signifie que vous vous connectez simplement avec sudo mysql . Si vous lancez sql :

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

alors vous le verrez :

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

Pour autoriser la connexion avec root et mot de passe, mettez à jour les valeurs dans le tableau avec la commande :

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

Ensuite, exécutez à nouveau la commande select et vous verrez qu'elle a changé :

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

Et c'est tout. Vous pouvez exécuter ce processus après avoir exécuté et terminé le sudo mysql_secure_installation commande.

Pour mariadb, utilisez

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

pour définir le mot de passe. Plus sur https://mariadb.com/kb/en/set- mot de passe/