หากคุณมีปัญหาเดียวกันใน MySql 5.7 +:
Access denied for user 'root'@'localhost'
มันเป็นเพราะ MySql 5.7 sudo mysqlโดยค่าเริ่มต้นช่วยให้การเชื่อมต่อกับซ็อกเก็ตซึ่งหมายความว่าคุณเพียงแค่เชื่อมต่อกับ หากคุณเรียกใช้ sql:
SELECT user,authentication_string,plugin,host FROM mysql.user;
แล้วคุณจะเห็นมัน:
+
| 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)
หากต้องการอนุญาตการเชื่อมต่อกับรูทและรหัสผ่านจากนั้นอัปเดตค่าในตารางด้วยคำสั่ง:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Current-Root-Password';
FLUSH PRIVILEGES;
จากนั้นเรียกใช้คำสั่ง select อีกครั้งและคุณจะเห็นว่ามีการเปลี่ยนแปลง:
+
| 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)
และนั่นแหล่ะ คุณสามารถรันกระบวนการนี้ได้หลังจากรันและทำตามsudo mysql_secure_installationคำสั่งเสร็จสิ้น
สำหรับ mariadb ให้ใช้
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');
เพื่อตั้งรหัสผ่าน เพิ่มเติมได้ที่https://mariadb.com/kb/en/set-password/
     
              
SHOW GRANTS FOR rootแบบสอบถามโพสต์ผลลัพธ์ในคำถามของคุณ