mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Hakey@12345'; ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
时间: 2023-12-22 11:02:33 浏览: 155
这个错误是因为你的 MySQL 服务器正在运行 `--skip-grant-tables` 选项,这个选项会跳过授权表的检查,允许所有用户访问所有数据库。在这种情况下,你不能使用 `ALTER USER` 命令来修改用户密码。
要解决这个问题,你需要先关闭 MySQL 服务器并重新启动,但是不要使用 `--skip-grant-tables` 选项。然后使用以下命令来修改用户密码:
```
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Hakey@12345';
```
如果你仍然无法修改密码,请检查当前 MySQL 用户是否具有足够的权限来修改其他用户密码。
相关问题
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456'; ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'
如果出现错误提示“Operation ALTER USER failed for 'root'@'localhost'”可能是由于 MySQL 8.0 引入了新的用户验证插件所致。在 MySQL 8.0 中,如果一个用户通过其他插件创建,那么在使用 ALTER USER 命令修改密码时,需要指定更改为 mysql_native_password 插件。
你可以使用以下步骤解决该问题:
1. 使用以下命令连接到 MySQL 服务:mysql -u root -p
2. 在 MySQL 命令行中,执行以下语句:
ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'password';
其中,将“password”替换为你想要设置的新密码。
3. 再次执行以下语句:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
其中,将“password”替换为你想要设置的新密码。
4. 退出 MySQL 命令行:exit
现在,你应该可以使用新密码连接到 MySQL 服务了。
alter user 'root'@'localhost' identified with mysql_native_password by 'Jj@123.com'; 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 'mysql> alter user 'root'@'localhost' identified with mysql_native_password by 'J' at line 1
这个错误可能是因为您在执行命令时没有以正确的方式输入MySQL命令。请尝试在命令行中输入以下内容,并按Enter键执行:
1. 输入mysql以进入MySQL控制台
2. 输入 USE mysql; 进入mysql库
3. 输入 ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Jj@123.com';
如果您仍然遇到问题,请提供更多详细信息,以便我能够更好地了解您的情况并提供更准确的帮助。
阅读全文