试着
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
得到
错误1064(42000):你有一个错误的SQL语法;查看手册
对应于你的MySQL服务器版本,正确的语法使用'IDENTIFIED BY 'root' WITH GRANT OPTION'在第一行。
注意:在以前的版本中尝试时,相同的工作。
也试过
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
得到
错误1410(42000):不允许使用GRANT创建用户
MySQL(8.0.11.0)用户名/密码为root/root。
1)这对我很管用。首先,创建一个新用户。示例:用户名为foo,密码为bar
> mysql> CREATE USER 'foo'@'localhost' IDENTIFIED WITH mysql_native_password BY 'bar';
2)将下面的代码替换为用户名'foo'。
> mysql> GRANT ALL PRIVILEGES ON database_name.* TO'foo'@'localhost';
注意:database_name是你想要拥有权限的数据库。意思是所有对所有
3)以foo用户登录
mysql> mysql -u foo -p
密码:酒吧
4)确保你的初始连接从Sequelize设置为foo与pw bar。
指定的用户在您的MySQL上不存在(因此,MySQL试图像在版本8之前那样使用GRANT创建它,但由于此版本引入的限制而失败)。
MySQL在这一点上是相当愚蠢的,所以如果你有'root'@'localhost',并试图授予'root'@'%'特权,它将它们视为不同的用户,而不是任何主机上的广义root用户,包括localhost。
错误消息也具有误导性。
因此,如果您得到错误消息,请使用以下内容检查现有用户
SELECT CONCAT("'", user, "'@'", host, "'") FROM mysql.user;
然后创建缺失的用户(正如Mike建议的那样),或者将GRANT命令调整为实际存在的用户规范。
我的规格:
mysql --version
mysql Ver 8.0.16 for Linux on x86_64 (MySQL Community Server - GPL)
对我有用的是:
mysql> CREATE USER 'username'@'localhost' IDENTIFIED BY 'desired_password';
mysql> GRANT ALL PRIVILEGES ON db_name.* TO 'username'@'localhost' WITH GRANT OPTION;
两个查询的响应:
Query OK, O rows affected (0.10 sec*)
注意:我之前创建了一个数据库(db_name),并创建了一个用户凭据,赋予数据库中所有表的所有特权,而不是使用我在某处读到的默认根用户,这是一个最佳实践。
这只是我对这个问题的看法。我有完全相同的问题,试图从MySQL工作台连接。我正在运行一个bitnami-mysql虚拟机来为开发设置一个本地沙盒。
Bitnami的教程说要运行“Grant All Privileges”命令:
/opt/bitnami/mysql/bin/mysql -u root -p -e "grant all privileges on *.* to 'root'@'%' identified by 'PASSWORD' with grant option";
这显然行不通,最后我用Mike Lischke的答案让它起作用了。
我认为发生的情况是root@%用户有与之关联的错误凭据。因此,如果你试图修改用户的特权,但运气不好,尝试:
删除用户。
重新创建用户。
确保在MySQL配置文件上有正确的绑定。
在我的例子中,我已经注释掉了这行,因为它只是用于沙盒环境。
1. 删除用户。
从Mysql控制台:
列出用户(有助于查看所有用户):
select user, host from mysql.user;
删除期望用户:
drop user '{{ username }}'@'%';
2. 重新创建用户。
创建用户并授予权限:
CREATE USER '{{ username }}'@'%' IDENTIFIED BY '{{ password }}';
GRANT ALL PRIVILEGES ON *.* TO '{{ username }}'@'%' WITH GRANT OPTION;
执行如下命令:
FLUSH PRIVILEGES;
3.确保在MySQL配置文件上有正确的绑定。
找到您的MySQL配置文件(附加说明在最后)。如果你想让MySQL监听多个网络上的连接,在配置文件中找到下面这行:
bind-address=127.0.0.1
并使用“#”注释它:
#bind-address=127.0.0.1
对于生产环境,您可能希望使用限制网络访问(最后的附加说明)。
然后重新启动MySQL服务。
希望这对有同样问题的人有所帮助!
绑定:如果你想了解更多,我建议你看看下面的内容
解决方案如何将MySQL服务器绑定到多个IP地址。它
基本上是说你可以打开MySQL,限制连接
防火墙,或者如果你的MySQL版本是8.0.13或更高。
该文件可以有不同的位置,这取决于你的
Linux分发和安装。在我的系统里,地址是
”“/ etc / my . cnf中所做。以下是其他推荐地点:
/etc/mysql/mysql.conf.d
/etc/mysql/my.cnf
你也可以搜索配置位置,如本网站所示:
如何找到MySQL配置文件的位置。
我看到了很多(错误的)答案,就像这样简单:
USE mysql;
CREATE USER 'user'@'localhost' IDENTIFIED BY 'P@ssW0rd';
GRANT ALL ON *.* TO 'user'@'localhost';
FLUSH PRIVILEGES;
注意:可以使用root来连接数据库,而不是自己创建的用户。但是,使用默认的根帐户让应用程序连接到数据库并不是首选的方法。可选特权可以按以下方式应用(请注意并记住最小特权原则):
-- Grant user permissions to all tables in my_database from localhost --
GRANT ALL ON my_database.* TO 'user'@'localhost';
-- Grant user permissions to my_table in my_database from localhost --
GRANT ALL ON my_database.my_table TO 'user'@'localhost';
-- Grant user permissions to all tables and databases from all hosts --
GRANT ALL ON *.* TO 'user'@'*';
如果你遇到以下错误:
错误1130 (HY000):主机' 1.2.3.4 '不允许连接到这个
MySQL服务器
您需要在/etc/mysql/my.cnf文件中增加/修改以下两行,并重新启动mysql。
bind-address = 0.0.0.0
skip-networking
你可能会遇到以下错误,这有点令人困惑:
错误1410(42000):不允许使用GRANT创建用户
这意味着要么用户根本不存在,要么user@host组合不存在。你可以用下面的命令检查:
SELECT host, user FROM user
1. 授予的权限
授予mysql>的所有权限。以授予选项“根”@“%”;
mysql> FLUSH PRIVILEGES
2. 检查用户表:
Mysql >使用Mysql
Mysql > select host,user from user
3.修改配置文件
Mysql默认绑定ip:127.0.0.1,如果我们要远程访问服务,只需删除配置
#Modify the configuration file
vi /usr/local/etc/my.cnf
#Comment out the ip-address option
[mysqld]
# Only allow connections from localhost
#bind-address = 127.0.0.1
4.最后重新启动服务
重启mysql
对于那些已经对创建用户'root'@'localhost'感到困惑的人,当你已经在服务器机器上有一个root帐户时,请记住,你的'root'@'localhost'和'root'@'your_remote_ip'是mysql服务器中两个不同的用户(相同的用户名,但不同的范围)。因此,创建一个带有your_remote_ip后缀的新用户实际上会创建一个新的有效的根用户,您可以使用该用户从远程机器访问mysql服务器。
例如,如果您使用root从IP为10.154.10.241的远程机器连接到mysql服务器,并且您希望为远程root帐户设置一个密码,该密码为'Abcdef123!@#',下面是你需要遵循的步骤:
On your mysql server machine, do mysql -u root -p, then enter your password for root to login.
Once in mysql> session, do this to create root user for the remote scope:
mysql> CREATE USER 'root'@'10.154.10.241' IDENTIFIED BY 'Abcdef123!@#';
After the Query OK message, do this to grant the newly created root user all privileges:
mysql> GRANT ALL ON *.* TO 'root'@'10.154.10.241';
And then:
FLUSH PRIVILEGES;
Restart the mysqld service:
sudo service mysqld restart
Confirm that the server has successfully restarted:
sudo service mysqld status
如果上面的步骤没有任何错误地执行,那么您现在可以使用root从远程机器访问mysql服务器。
以我为例,我想做一些类似的事情,我遵循了这里的一些步骤,但最好的方法是@星云提到的:
USE mysql;
CREATE USER 'user'@'localhost' IDENTIFIED BY 'P@ssW0rd';
GRANT ALL ON *.* TO 'user'@'localhost';
FLUSH PRIVILEGES;
在这之后,我遇到了一个错误,而试图查询数据库或连接SQLTools从VSCode。
客户端不支持服务器请求的认证协议;考虑升级MySQL客户端
运行这个查询将修复这个问题:
ALTER USER 'user'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Your_newP@s$w0Rd';
我还想提到的是,这些步骤在本地环境中是可以工作的,在生产环境中执行某些操作时,建议将每个用户分配到每个数据库,并相应生成密码,如果需要,还可以采取不同的其他安全措施。