MySQL 的 GRANT和REVOKE 命令
MySQL 的 GRANT和REVOKE 命令
GRANT - 授权
将指定
操作对象
的指定操作权限
授予指定的用户
; 发出该 GRANT语句的可以是数据库管理员,也可以是该数据库对象的创建者;
查询
查看用户自己权限
SHOW GRANTS;
查看其他用户权限
SHOW GRANTS FOR 'user'@'host';
Tips: host 可以使用通配符
%
;如 'user'@'%', 'user'@'192.168.0.%';授权
语法
GRANT 权限 ON 数据库对象 TO 用户 [WITH GRANT OPTION];
栗子
授予 super用户所有权限
GRANT ALL [PRIVILEGES] ON . TO 'user'@'%';
授予用户 INSERT 权限
CREATE INSERT ON db_name.* TO 'user'@'%' IDENTIFIED BY 'newpasswd';
授予用户 SELECT, UPDATE, DELETE 权限
GRANT SELECT, UPDATE, DELETE ON db_name.* TO 'user'@'localhost'
刷新
FLUSH PRIVILEGES;
Tips:
WITH GRANT OPTION
: 表示是否能传播其权限;(授权命令是由数据库管理员使用的)- 指定
WITH GRANT OPTION
,则获得该权限的用户可以把这种权限授予其他用户;但不允许循环传授,即被授权者不能把权限在授回给授权者或祖先; - 未指定,则获得某种权限的用户只能自己使用该权限,不能传播该权限;
- 指定
- 在
GRANT
关键字之后指定一个或多个
特权。如果要授予用户多个权限,则每个权限都将以逗号
分隔(见下表中的特权列表); - 指定确定特权应用级别的privilege_level;
- MySQL支持全局(
*.*
),数据库(database.*
),表(database.table
)和列级别; - 如果您使用列权限级别,则必须在每个权限之后使用
逗号
分隔列的列表;
- MySQL支持全局(
- 如果授予权限的用户已经存在,则GRANT语句修改其特权; 如不存在,则GRANT语句将创建一个新用户; 可选的条件
IDENTIFIED BY
允许为用户设置新密码;
REVOKE - 回收授权
语法
REVOKE 权限 ON 数据库对象 FROM 用户 [CASCADE | RESTRICT];
栗子
回收全部权限
REVOKE ALL [PRIVILEGES] ON . FROM 'user'@'%';
回收 INSERT 权限
REVOKE INSERT ON db_name.* FROM 'user'@'%';
Tips:
CASCADE | RESTRICT
当检测到关联的特权时,RESTRICT(默认值) 导致REVOKE失败;CASCADE
可以回收所有这些关联的特权;(如U1授权U2, U2授权U3,此时使用级联(CASCADE)收回了U2和U3的权限,否则系统将拒绝执行该命令)
GRANT允许的特权
下表说明了可用于GRANT和REVOKE语句的所有可用权限:
权限 含义 全局 数据库 表 列 过程 代理 ALL [PRIVILEGES]
授予除了grant option之外的指定访问级别的所有权限 ALTER
允许用户使用alter table语句 X X X ALTER ROUTINE
允许用户更改或删除存储程序, 可以使用{alter | drop} {procedure | unction} X X X CREATE
允许用户创建数据库和表 X X X CREATE ROUTINE
可以使用{create | alter | drop} {procedure | function} X CREATE TABLESPACE
允许用户创建,更改或删除表空间和日志文件组 X CREATE TEMPORARY TABLES
允许用户使用create temporary table创建临时表 X X CREATE USER
允许用户使用create user,drop user,rename user和revoke all privileges语句 X CREATE VIEW
允许用户创建或修改视图 X X X DELETE
允许用户使用delete X X X DROP
允许用户删除数据库,表和视图 X X X EVENT
能够使用事件计划的事件 X X EXECUTE
允许用户执行存储过程/存储函数 X X FILE
允许用户读取数据库目录中的任何文件 X GRANT OPTION
允许用户有权授予或撤销其他帐户的权限 X X X X X INDEX
允许用户创建或删除索引 X X X INSERT
允许用户使用insert语句 X X X X LOCK TABLES
允许用户在具有select权限的表上使用lock tables X X PROCESS
允许用户使用show processlist语句查看所有进程 X PROXY
启用用户代理 REFERENCES
允许用户创建外键 X X X X RELOAD
允许用户使用flush操作 X REPLICATION CLIENT
允许用户查询主服务器或从服务器的位置 X REPLICATION SLAVE
允许用户使用复制从站从主机读取二进制日志事件 X SELECT
允许用户使用select语句 X X X X SHOW DATABASES
允许用户显示所有数据库 X SHOW VIEW
允许用户使用show create view语句 X X X SHUTDOWN
允许用户使用mysqladmin shutdown命令 X SUPER
允许用户使用其他管理操作,如change master to,kill,purge binary logs,set global和mysqladmin命令 X TRIGGER
允许用户使用trigger操作 X X X UPDATE
允许用户使用update语句 X X X X USAGE
连接(登陆)权限(默认授予且不能被回收)
实例
用户操作
创建用户
CREATE USER 'user'@'%' IDENTIFIED BY 'newpasswd';
重命名用户
CREATE USER 'old_user'@'%' TO 'new_user'@'%';
删除用户
查询用户
SELECT user,host FROM mysql.user;
删除用户
DROP USER 'user'@'host';
查看和刷新权限
查看权限
SHOW GRANTS [FOR 'user'@'host'];
刷新权限
FLUSH PRIVILEGES;
授权与取消授权
用法
GRANT 权限 ON 数据库对象 TO 用户 [WITH GRANT OPTION]; -- 授权
REVOKE 权限 ON 数据库对象 FROM 用户 [CASCADE | RESTRICT]; -- 取消授权
Tips: REVOKE 跟 GRANT 的语法差不多,只需要把关键字
TO
换成FROM
即可栗子
添加权限(和已有权限合并,不会覆盖已有权限)
-- 添加普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利
grant select, insert, update, delete on testdb.* to common_user@'%' -- 添加数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限
grant create, alter, drop on testdb.* to developer@'192.168.0.%'; -- 添加操作 MySQL 外键权限
grant references on testdb.* to developer@'192.168.0.%'; -- 添加操作 MySQL 临时表权限
grant create temporary tables on testdb.* to developer@'192.168.0.%'; -- 添加操作 MySQL 索引权限
grant index on testdb.* to developer@'192.168.0.%'; -- 添加操作 MySQL 视图、查看视图源代码 权限
grant create, show view on testdb.* to developer@'192.168.0.%';
删除授权
-- 删除普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利
revoke select, insert, update, delete on testdb.* from common_user@'%' -- 删除数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限
revoke create, alter, drop on testdb.* from developer@'192.168.0.%'; -- 删除操作 MySQL 外键权限
revoke references on testdb.* from developer@'192.168.0.%'; -- 删除操作 MySQL 临时表权限
revoke create temporary tables on testdb.* from developer@'192.168.0.%'; -- 删除操作 MySQL 索引权限
revoke index on testdb.* from developer@'192.168.0.%'; -- 删除操作 MySQL 视图、查看视图源代码 权限
revoke create, show view on testdb.* from developer@'192.168.0.%';
DBA 权限管理
-- 普通 DBA 管理某个 MySQL 数据库的权限
grant all [privileges] on testdb to dba@'localhost' -- 高级 DBA 管理 MySQL 中所有数据库的权限。
grant all on *.* to dba@'localhost'
细密度授权
-- 作用在整个 MySQL 服务器上
grant select on *.* to dba@localhost; -- dba 可以查询 MySQL 中所有数据库中的表
grant all on *.* to dba@localhost; -- dba 可以管理 MySQL 中的所有数据库 -- 作用在单个数据库上
grant select on testdb.* to dba@localhost; -- dba 可以查询 testdb 中的表。 -- 作用在单个数据表上
grant select, insert, update, delete on testdb.t_orders to dba@localhost; -- 作用在表中的列上
grant select(id, username, sex) on testdb.t_user to dba@localhost;
权限传播与收回
-- 授权 dba 查询权限,并且可以将这些权限 grant 给其他用户
grant select on testdb.* to dba@localhost with grant option; -- 收回 dba 和其传播用户的权限
revoke select on testdb.* from dba@localhost cascade;
Tips: 权限发生改变后, 需要重新加载一下权限,将权限信息从内存中写入数据库;
Reference
MySQL 的 GRANT和REVOKE 命令的更多相关文章
- MySQL的grant,revoke使用
MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利. grant sele ...
- MySQL的Grant命令[转]
本文实例,运行于 MySQL 5.0 及以上版本. MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删 ...
- mysql grant ,User,revoke
mysql的权限一直都都是很关心的重点,我知道的也只是很少的一部分,对于每个数据库我习惯创建一个一个用户,该用户只对自己从属的数据库产生进行操作,在一部分的程度上可以保护自己的数据库, 比如我有一个数 ...
- [MySQL] - MySQL的Grant命令
本文实例,运行于 MySQL 5.0 及以上版本. MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删 ...
- MySQL的Grant命令
来源:http://yingxiong.javaeye.com/blog/451208 本文实例,运行于 MySQL 5.0 及以上版本. MySQL 赋予用户权限命令的简单格式可概括为: gra ...
- (转)MySQL的Grant命令
[MySQL] - MySQL的Grant命令 来源:http://yingxiong.javaeye.com/blog/451208 本文实例,运行于 MySQL 5.0 及以上版本. MySQL ...
- MySQL的GRANT命令(创建用户)
本文实例,运行于 MySQL 5.0 及以上版本. MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 (删除用户与删除权限:drop user '用户名 ...
- MySQL数据库grant授权命令
MySQL数据库grant授权命令 制作人:全心全意 grant授权命令的使用 grant授权命令使用语法: grant 权限 on 数据库对象 to 用户 grant 权限 on 数据库对象 to ...
- mysql数据库备份与还原命令
还原一个数据库:mysql -h localhost -u root -p123456 www 备份一个数据库:mysqldump -h localhost -u root -p123456 www ...
随机推荐
- systemd --user进程CPU占用高问题分析
1.问题由来 近期发现堡垒机环境有如下问题,systemd占用大量cpu: 原文链接:https://www.cnblogs.com/yaohong/p/16046670.html 2.问题定位 2. ...
- luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分)
luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分) Luogu 题解时间 $ k $ 条边权为 $ 0 $ 的边. 是的,边权为零. 转化成选正好 $ k+1 $ 条链. $ ...
- CF1553X Harbour.Space Scholarship Contest 2021-2022 (Div. 1 + Div. 2)
掉大分 E 对于一个序列,把它排回去的最小次数是 $\sum置换环大小-1=错位个数-置换环个数$ 注意到m小于等于n/3.那么最多修正2m个错位.正确位置的个数必须大于等于n/3才可能在m次内修正. ...
- RenderDoc图形调试器详细使用教程(基于DirectX11)
前言 由于最近Visual Studio的图形调试器老是抽风,不得不寻找一个替代品了. 对于图形程序开发者来说,学会使用RenderDoc图形调试器可以帮助你全面了解渲染管线绑定的资源和运行状态,从而 ...
- Linux 性能调优都有哪几种方法?
1.Disabling daemons (关闭 daemons). 2.Shutting down the GUI (关闭 GUI). 3.Changing kernel paramete ...
- abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized?
abstract的method 不可以是static的,因为抽象的方法是要被子类实现的,而static与子类扯不上关系! native方法表示该方法要用另外一种依赖平台的编程语言实现的,不存在着被子类 ...
- BeanFactory和ApplicationContext有什么区别?
BeanFactory和ApplicationContext是Spring的两大核心接口,都可以当做Spring的容器.其中ApplicationContext是BeanFactory的子接口. (1 ...
- kafka-linux-install
linux按照kafka 必须先按照java jdk包!!!!!!!!!!!! 先安装zookeeper 下载:http://mirrors.hust.edu.cn/apache/zookeeper/ ...
- Bootstrap Javascript组件,模态框级联open解决方案
<script type="text/javascript"> top.global={zIndex:null}; $("body>div[data-m ...
- Java 中,嵌套公共静态类与顶级类有什么不同?
类的内部可以有多个嵌套公共静态类,但是一个 Java 源文件只能有一个顶级公 共类,并且顶级公共类的名称与源文件名称必须一致.