Mysql的权限
mysql中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表。
mysql权限表的验证过程为:
先从user表中的Host,User,Password这3个字段中判断连接的ip、用户名、密码是否存在,存在则通过验证。
通过身份认证后,进行权限分配,按照user,db,tables_priv,columns_priv的顺序进行验证。
即先检查全局权限表user,如果user中对应的权限为Y,则此用户对所有数据库的权限都为Y,将不再检查db, tables_priv,columns_priv;
如果为N,则到db表中检查此用户对应的具体数据库,并得到db中为Y的权限;
如果db中为N,则检查tables_priv中此数据库对应的具体表,取得表中的权限Y,以此类推。
1.查询数据库的用户名,主机,密码
mysql>select user,host,password from mysql.user;
2.显示某个用户的授权命令
mysql>show grants for rep@'%';
3.赋予某个用户对库test进行select,insert,update,delete的权限的命令如下
mysql>grant select,insert,update,delete on test.* to user01@'10.200.20.%' identified by '123';
4.赋予备份整个实例权限的命令
mysql>grant lock tables,