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-password/で詳細を見る
SHOW GRANTS FOR root
クエリで実行し、結果を質問に投稿します。