Si vous rencontrez le même problème dans MySql 5.7. +:
Access denied for user 'root'@'localhost'
c'est parce que MySql 5.7 par défaut permet de se connecter avec socket, ce qui signifie que vous venez de vous connecter avec sudo mysql
. Si vous exécutez 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 de sélection 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é la sudo mysql_secure_installation
commande.
Pour mariadb, utilisez
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');
pour définir le mot de passe. Plus d'informations sur https://mariadb.com/kb/en/set-password/
SHOW GRANTS FOR root
une requête, publiez le résultat dans votre question.