工作中,有时候会遇到分享本地数据库给同事使用的情况。下面是可能用到的一些操作。相互借鉴。
分配用户权限
格式
分配用户权限时,可以控制用户对数据的增删改查等,也可以控制用户只可以查看数据库中的具体表
eg:
GRANT
SELECT,
INSERT,
UPDATE,
DELETE,
CREATE,
DROP
ON database1.investor TO [email protected] IDENTIFIED BY '000000';
此例子表示,分配给ck(这个用户可以已经创建,也可以未创建)用户在本地(localhost)的database1数据库中investor表拥有SELECT、INSERT、UPDATE、DELETE、CREATE、DROP 这几个操作权限;没有其他表的其他任何权限。连接数据库的密码是:000000
当然更多的时候我们还是分配足够的权限给他人使用。此时可以使用如下语句:
此语句表示,分配所有权限给root这个用户在本地的所有数据库的所有表的所有权限。连接数据库的密码是:123456
取消分配权限
格式
取消用户权限时,可以控制用户对数据的增删改查等,也可以控制用户只可以查看数据库中的具体表
Revoke privileges (columns) on what from user ;
eg:
REVOKE
SELECT,
INSERT,
UPDATE,
DELETE,
CREATE,
DROP
ON database1.investor from [email protected];
此例子与上述分配权限例子一致,只是这边是取消权限。
取消所有数据库的所有权限时:
Revoke all on *.* from [email protected];
取消本地用户ck在所有数据库的所有权限。
取消用户权限后,访问会出现如图提示:
删除数据库用户
格式
eg:
DELETE from mysql.`user` WHERE `User`='ck' AND `Host` = 'localhost';
FLUSH PRIVILEGES;
这边要说明一下的是,格式中user在mysql中表现形式是:mysql.
user
。
此语句表示,删除用户ck在本地的访问权限(用户ck可能有三个ip使用,这样只是控制某一个ip的权限)。
FLUSH PRIVILEGES是告诉数据库服务,刷新权限,再次请求时,需要重新拉去权限。
删除所有用户这个还是不教了,怕你手快,怕你骂人。
删除用户后,访问会出现如图提示:
查看所有用户:
可通过查询的语句,知道某一用户的权限。
参考文章:http://www.2cto.com/database/201309/242823.html