Maison > Questions et réponses > le corps du texte
P粉8645949652023-08-08 13:46:16
Si vous rencontrez ce problème dans MySQL 5.7.+ :
Access denied for user 'root'@'localhost'
Étant donné que MySQL 5.7 autorise les connexions via des sockets par défaut, cela signifie que vous devez uniquement vous connecter à MySQL avec les privilèges d'administrateur.
SELECT user,authentication_string,plugin,host FROM mysql.user;
Alors tu vois
+------------------+-------------------------------------------+-----------------------+-----------+ | 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)
Autoriser la connexion avec les droits d'administrateur et la saisie d'un mot de passe, puis mettre à jour les valeurs dans le tableau via 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)
Alors ça y est. Après avoir terminé la commande sudo mysql_secure_installation, vous pouvez exécuter la procédure suivante.
Pour mariadb, utilisez :
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');
Ensuite, il est temps de définir un mot de passe. Pour plus d'informations, consultez https://mariadb.com/kb/en/set-password/.
P粉6475042832023-08-08 09:12:02
Instructions pour utiliser la réinitialisation du mot de passe - mais au lieu de réinitialiser le mot de passe, forcez l'insertion d'un enregistrement dans la table mysql.user
INSERT INTO mysql.user (Host, User, Password) VALUES ('%', 'root', password('YOURPASSWORD')); GRANT ALL ON *.* TO 'root'@'%' WITH GRANT OPTION;