您的位置:首页 > 数据库 > MySQL

mysql 用户的权限 问题帖子

2009-07-22 22:48 218 查看
在授权一个用户之后

grant select,insert,update,delete,create,drop on haha.* to haha@localhost identified by 'pwd';

我删除了这个用户的权限.和用户

revoke all on haha.* from haha@localhost;

delete from mysql.user where user='haha' and host='localhost';

出现的问题是:在删除权限之前,是以授权的密码进入.但是删除授权之后,竟然不需要密码了.

直接: mysql -u haha -p,回车之后进入了.而且权限比较大.

请问怎么会出现这个问题,怎么解决.

已经baidu,google过了.

盼回复.

delete 操作后,要再下 flush privileges 指令刷新内存中的权限表,你现在用这个命令试试。

不过在这之前,麻烦贴一下下面的结果(纯属我比较好奇你现在的状况):

select host, user from mysql.user;

select user();

show grants for 上一条指令的结果;

mysql> select host, user from mysql.user;

+-----------+------+

| host      | user |

+-----------+------+

| localhost |      |

| localhost | root |

+-----------+------+

2 rows in set (0.02 sec)

mysql> select user();

+----------------+

| user()         |

+----------------+

| root@localhost |

+----------------+

1 row in set (0.01 sec)

user表里面根本就没有这样的用户.而且,delete之后都会flush一下.这个还是知道的.

在看了键入了大大给我的指令之后,我发现有个用户名为空,密码为空的用户了.上面可以看见的.于是我就

delete from mysql.user where user=' ' and host='localhost';

后来就不能空用户名和密码登陆了.

这是为什么?有空用户名存在?第一次听说,也许是我孤陋寡闻了.

默认都是有一个空用户名的账号存在,就是让用户可以匿名登录,但默认权限只能使用 test 数据库。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息