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 数据库。
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 数据库。
相关文章推荐
- 关于mysql用户权限的问题
- MySQL用户权限分配问题
- 在Linux下给mysql创建用户并分配权限及问题解决方案
- 在Linux下给mysql创建用户并分配权限等问题
- mysql用户权限问题
- Mysql权限,用户添加,远程连接问题汇总
- MySQL 5.7 第一次登录用户权限问题
- linux下mysql 创建数据库分配用户权限问题
- MySQL 用户登录密码和远程登录权限问题
- mysql 用户登录密码和远程登录权限问题
- MySQL的用户权限设置问题(如何解决Access denied)
- mysql 用户访问权限问题
- MySQL的用户权限设置问题
- MYSQL用户创建删除和权限问题
- mysql 从库设置read-only 对super权限的用户无效的问题
- 使用root用户远程登录mysql没有trigger权限的问题
- MySQL修改root用户密码引起的root超级权限丢失的问题(Mac平台
- mysql由于权限问题看不到用户数据库
- mysql由于权限问题看不到用户数据库
- mysql用户权限管理的问题