Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Acesso negado para usuário 'root'@'localhost' (usando senha:YES) - Sem privilégios?


Se você tiver esse mesmo problema no MySql 5.7.+ :
Access denied for user 'root'@'localhost'

é porque o MySql 5.7 por padrão permite conectar com socket, o que significa que você apenas conecta com sudo mysql . Se você executar sql:
SELECT user,authentication_string,plugin,host FROM mysql.user;

então você vai ver:
+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

Para permitir a conexão com root e senha, atualize os valores na tabela com o comando:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Current-Root-Password';
FLUSH PRIVILEGES;

Em seguida, execute o comando select novamente e você verá que ele mudou:
+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

E é isso. Você pode executar este processo depois de executar e concluir o sudo mysql_secure_installation comando.

Para mariadb, use
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');

para definir a senha. Mais em https://mariadb.com/kb/en/set- senha/