Mysql
 sql >> база данни >  >> RDS >> Mysql

Достъпът е отказан за потребител 'root'@'localhost' (използвайки парола:ДА) - Няма привилегии?

Ако имате същия проблем в 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)

За да разрешите връзка с root и парола, след това актуализирайте стойностите в таблицата с команда :

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- парола/



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Как да импортирате база данни с помощта на командния ред

  2. Различните бази данни използват ли различни цитати на имена?

  3. Разширението mysqli липсва, phpmyadmin не работи

  4. Как да се свържете с MySQL или MariaDB база данни

  5. Реализация на разстоянието на Левещайн за mysql/размито търсене?