我已经定义了MySQL 5:
CREATE DATABASE foo DEFAULT CHARACTER SET = 'utf8';
GRANT ALL ON foo.* TO foo@'%' IDENTIFIED BY 'foo';
FLUSH PRIVILEGES;
但是,当用户foo
访问时,传递foo
,拒绝连接。
当我将其更改为
GRANT ALL ON foo.* TO foo@localhost IDENTIFIED BY 'foo';
MySQL让我进来。
为什么第一个不起作用? AFAIK,%
应匹配任何内容。
更新:发现此信息,可能与http://forums.mysql.com/read.php?30,158830,158830
有关手动参考:(在那里找不到答案)
答案 0 :(得分:3)
来自mysql documentation:
一个非常常见的错误是插入一个包含Host ='%'和User ='some_user'的新条目,认为这使您可以指定localhost从同一台计算机进行连接。这不起作用的原因是默认权限包括Host ='localhost'和User =''的条目。因为该条目具有比'%'更具体的主机值'localhost',所以当从localhost连接时,它优先于新条目使用!正确的过程是插入第二个条目,其中Host ='localhost'和User ='some_user',或删除具有Host ='localhost'和User =''的条目。删除条目后,请记住发出FLUSH PRIVILEGES语句以重新加载授权表。另请参见第6.2.4节“访问控制,第1阶段:连接验证”。
执行第一个命令后检查mysql.user
表
CREATE DATABASE foo DEFAULT CHARACTER SET = 'utf8';
GRANT ALL ON foo.* TO foo@'%' IDENTIFIED BY 'foo';
FLUSH PRIVILEGES;
select * from mysql.user where User='foo';