GRANT ALL PRIVILEGES ON *.* TO 'rooy'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;报错
时间: 2024-06-08 13:04:56 浏览: 104
MySQL命令行下18个常用命令
当执行GRANT ALL PRIVILEGES ON *.* TO 'rooy'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;这条语句时,如果报错"The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement",那是因为MySQL服务器正在使用--skip-grant-tables选项运行,这个选项会跳过权限验证。在这种情况下,你无法执行GRANT语句来授权用户。
要解决这个问题,有两种方法可以尝试:
1. 重启MySQL服务,不使用--skip-grant-tables选项。这将恢复权限验证功能,然后你可以重新执行GRANT语句。
2. 如果你无法重启MySQL服务,你可以尝试执行以下步骤来授权用户:
a. 登录MySQL,以root用户身份执行ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';命令来修改root用户的密码。
b. 修改MySQL配置文件,找到并删除或注释掉skip-grant-tables选项。
c. 保存并退出配置文件,然后重新启动MySQL服务。
d. 登录MySQL,以root用户身份执行GRANT ALL PRIVILEGES ON *.* TO 'rooy'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;命令来授权用户。
通过上述方法,你应该能够成功执行GRANT语句并授权用户。请注意,根据你的具体情况和MySQL版本,可能会有所不同。因此,建议在执行任何操作之前先备份重要的数据和配置文件。
阅读全文