一.权限表
mysql数据库中的3个权限表:user 、db、 host
权限表的存取过程是:
1)先从user表中的host、 user、 password这3个字段中判断连接的IP、用户名、密码是否存在表中,存在则通过身份验证;
2) 通过权限验证,进行权限分配时,按照user?db?tables_priv?columns_priv的顺序进行分配。即先检查全局权限表 user,如果user中对应的权限为Y,则此用户对所有数据库的权限都为Y,将不再检查db, tables_priv,columns_priv;如果为N,则到db表中检查此用户对应的具体数据库,并得到db中为Y的权限;如果db中为N,则检查tables_priv中此数据库对应的具体表,取得表中的权限Y,以此类推。
二.MySQL各种权限(共27个)
(以下操作都是以root身份登陆进行grant授权,以p1@localhost身份登陆执行各种命令。)
1. usage
连接(登陆)权限,建立一个用户,就会自动授予其usage权限(默认授予)。
该权限只能用于数据库登陆,不能执行任何操作;且usage权限不能被回收,也即REVOKE用户并不能删除用户。
2. select
必须有select的权限,才可以使用select table
3. create
必须有create的权限,才可以使用create table
4. create routine
必须具有create routine的权限,才可以使用{create |alter|drop} {procedure|function}
当授予create routine时,自动授予EXECUTE, ALTER ROUTINE权限给它的创建者:
5. create temporary tables(注意这里是tables,不是table)
必须有create temporary tables的权限,才可以使用create temporary tables.
6. create view
必须有create view的权限,才可以使用create view
7. create user
要使用CREATE USER,必须拥有mysql数据库的全局CREATE USER权限,或拥有INSERT权限。
8. insert
必须有insert的权限,才可以使用insert into ….. values….
9. alter
必须有alter的权限,才可以使用alter table
alter table shop modify dealer char(15);
10. alter routine
必须具有alter routine的权限,才可以使用{alter |drop} {procedure|function}
11. update
必须有update的权限,才可以使用update table
12. delete
必须有delete的权限,才可以使用delete from ….where….(删除表中的记录)
13. drop
必须有drop的权限,才可以使用drop database db_name; drop table tab_name;
drop view vi_name; drop index in_name;
14. show database
通过show database只能看到你拥有的某些权限的数据库,除非你拥有全局SHOW DATABASES权限。
对于p1@localhost用户来说,没有对mysql数据库的权限,所以以此身份登陆查询时,无法看到mysql数据库:
15. show view
必须拥有show view权限,才能执行show create view。
16. index
必须拥有index权限,才能执行[create |drop] index
1 mysql> grant index on pyt.* to p1@localhost; 2 mysql> create index ix_shop on shop(article); 3 mysql> drop index ix_shop on shop;
17. excute
执行存在的Functions,Procedures
1 mysql> call pro_shop1(0001,@a); 2 +———+ 3 | article | 4 +———+ 5 | 0001 | 6 | 0001 | 7 +———+ 8 mysql> select @a; 9 +——+ 10 | @a | 11 +——+ 12 | 2 | 13 +——+
18. lock tables
必须拥有lock tables权限,才可以使用lock tables
1 mysql> grant lock tables on pyt.* to p1@localhost; 2 mysql> lock tables a1 read; 3 mysql> unlock tables;
19. references
有了REFERENCES权限,用户就可以将其它表的一个字段作为某一个表的外键约束。
20. reload
必须拥有reload权限,才可以执行flush [tables | logs | privileges]
1 mysql> grant reload on pyt.* to p1@localhost; 2 ERROR 1221 (HY000): Incorrect usage of DB GRANT and GLOBAL PRIVILEGES 3 mysql> grant reload on *.* to ‘p1′@’localhost’; 4 Query OK, 0 rows affected (0.00 sec) 5 mysql> flush tables;
21. replication client
拥有此权限可以查询master server、slave server状态。
1 mysql> show master status; 2 ERROR 1227 (42000): Access denied; you need the SUPER,REPLICATION CLIENT privilege for this operation 3 mysql> grant Replication client on *.* to p1@localhost; 4 或:mysql> grant super on *.* to p1@localhost; 5 mysql> show master status; 6 +——————+———-+————–+——————+ 7 | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | 8 +——————+———-+————–+——————+ 9 | mysql-bin.000006 | 2111 | | | 10 +——————+———-+————–+——————+ 11 mysql> show slave status;
22. replication slave
拥有此权限可以查看从服务器,从主服务器读取二进制日志。
1 mysql> show slave hosts; 2 ERROR 1227 (42000): Access denied; you need the REPLICATION SLAVE privilege for this operation 3 mysql> show binlog events; 4 ERROR 1227 (42000): Access denied; you need the REPLICATION SLAVE privilege for this operation 5 mysql> grant replication slave on *.* to p1@localhost; 6 mysql> show slave hosts; 7 Empty set (0.00 sec) 8 mysql>show binlog events; 9 +—————+——-+—————-+———–+————-+————–+ 10 | Log_name | Pos | Event_type | Server_id| End_log_pos|Info | +—————+——-+————–+———–+————-+—————+ 11 | mysql-bin.000005 | 4 | Format_desc | 1 | 98 | Server ver: 5.0.77-log, Binlog ver: 4 | |mysql-bin.000005|98|Query|1|197|use `mysql`; create table a1(i int)engine=myisam| 12 ……………………………………
23. Shutdown
关闭MySQL:
1 [mysql@mydev ~]$ mysqladmin shutdown 2 重新连接: 3 [mysql@mydev ~]$ mysql 4 ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2) 5 [mysql@mydev ~]$ cd /u01/mysql/bin 6 [mysql@mydev bin]$ ./mysqld_safe & 7 [mysql@mydev bin]$ mysql
24. grant option
拥有grant option,就可以将自己拥有的权限授予其他用户(仅限于自己已经拥有的权限)
1 mysql> grant Grant option on pyt.* to p1@localhost; 2 mysql> grant select on pyt.* to p2@localhost;
25. file
拥有file权限才可以执行 select ..into outfile和load data infile…操作,但是不要把file, process, super权限授予管理员以外的账号,这样存在严重的安全隐患。
1 mysql> grant file on *.* to p1@localhost; 2 mysql> load data infile ‘/home/mysql/pet.txt’ into table pet;
26. super
这个权限允许用户终止任何查询;修改全局变量的SET语句;使用CHANGE MASTER,PURGE MASTER LOGS。
1 mysql> grant super on *.* to p1@localhost; 2 mysql> purge master logs before ‘mysql-bin.000006′;
27. process
通过这个权限,用户可以执行SHOW PROCESSLIST和KILL命令。默认情况下,每个用户都可以执行SHOW PROCESSLIST命令,但是只能查询本用户的进程。
1 mysql> show processlist; 2 +—-+——+———–+——+———+——+——-+——————+ 3 | Id | User | Host | db | Command | Time | State | Info | 4 +—-+——+———–+——+———+——+——-+——————+ 5 | 12 | p1 | localhost | pyt | Query | 0 | NULL | show processlist | 6 +—-+——+———–+——+———+——+——-+——————+
另外,
管理权限(如 super, process, file等)不能够指定某个数据库,on后面必须跟*.*
1 mysql> grant super on pyt.* to p1@localhost; 2 ERROR 1221 (HY000): Incorrect usage of DB GRANT and GLOBAL PRIVILEGES 3 mysql> grant super on *.* to p1@localhost; 4 Query OK, 0 rows affected (0.01 sec)
这个有哟娜用 的 mysql> grant super on *.* to p1@localhost;
原文:https://www.cnblogs.com/new-journey/p/10429914.html