所以我得到了非常常见的ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
mysql错误。我已经尝试了论坛上的所有典型修复,通过 mysql_safe 方法登录,然后尝试重置我的 root 密码。但是,这样做时它会返回;
UPDATE user SET password=PASSWORD("PASSWORD")WHERE user="root";
Query OK, 0 rows affected (0.00 sec)
Rows matched: 0 Changed: 0 Warnings: 0
因此,由于没有行受到影响,我假设没有用户实际更改。我试图创建一个用户:
CREATE USER 'root'@'localhost' IDENTIFIED BY 'root'
-> GRANT ALL ON *.* TO 'root'@'localhost'
-> flush privileges;
However this returns with ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'GRANT ALL ON *.* TO 'root'@'localhost'
查看当前用户是什么:
mysql> SELECT user();
+--------+
| user() |
+--------+
| root@ |
+--------+
我认为语法错误是“root”之后的@之后没有任何内容。如何将此信息编辑为 root@localhost 并更正问题?
更新
在仔细阅读了 mysqld 文档后,我进入了这个完美运行的部分。
停止 mysqld 并使用 --skip-grant-tables 选项重新启动它。这使任何人都可以在没有密码和所有权限的情况下进行连接。因为这是不安全的,您可能希望将 --skip-grant-tables 与 --skip-networking 结合使用以防止远程客户端连接。
使用以下命令连接到 mysqld 服务器:
shell> mysql
在 mysql 客户端中发出以下语句。将密码替换为您要使用的密码。
mysql> UPDATE mysql.user SET Password=PASSWORD('MyNewPass')
-> WHERE User='root';
mysql> FLUSH PRIVILEGES;
FLUSH 语句告诉服务器将授权表重新加载到内存中,以便它注意到密码更改。