sql >> Database >  >> RDS >> Mysql

Toegang geweigerd voor gebruiker 'root'@'localhost' (met wachtwoord:JA) - Geen rechten?

Als je hetzelfde probleem hebt in MySql 5.7.+ :

Access denied for user 'root'@'localhost'

het is omdat MySql 5.7 standaard toestaat om verbinding te maken met socket, wat betekent dat je gewoon verbinding maakt met sudo mysql . Als u sql gebruikt:

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

dan zul je het zien:

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

Om verbinding met root en wachtwoord toe te staan, werk dan de waarden in de tabel bij met het commando :

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

Voer vervolgens het select-commando opnieuw uit en u zult zien dat het is veranderd:

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

En dat is het. U kunt dit proces uitvoeren na het uitvoeren en voltooien van de sudo mysql_secure_installation commando.

Gebruik voor mariadb

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

om het wachtwoord in te stellen.Meer op https://mariadb.com/kb/en/set- wachtwoord/



  1. Top 3 redenen waarom mensen overstappen op SaaS

  2. Opgeslagen procedure uitvoeren vanuit Laravel

  3. SQL ALTER TABLE voor beginners

  4. Database aanmaken in MySQL