mysql用户权限控制sql语法案例
- 用户管理
- 创建用户
- 删除用户
- 设置密码
- 权限管理
- 授权
- 撤销授权
- 刷新权限
一、用户管理
1.创建用户
语法:create user [用户名] identified by '[密码]'
create user jiajia IDENTIFIED by 'jiajia'; -- 所有连接
create user jiajia2@'127.0.0.1' IDENTIFIED by 'jiajia2'; -- 本地连接
create user jiajia3@'192.168.%' IDENTIFIED by 'jiajia3'; -- 某网段才能连接
2.查询mysql中所有的用户
SELECT * from mysql.user;
3.删除用户
-- 删除用户
drop user jiajia2@'127.0.0.1';
-- 或者
DELETE FROM mysql.user WHERE `user`='jiajia' and HOST = '%'
4.设置密码
语法:set password for '用户名' @host=password('新密码')
使用password()
进行加密
set password for 'jiajia2'@127.0.0.1=password('123456');
-- 或者
update mysql.user set `authentication_string`=password('123456') where user='jiajia2' and host='127.0.0.1';
二、权限管理
1.查看当前登录用户权限
show GRANTS;
2.查看用户的权限信息
语法:SHOW GRANTS FOR 'username'@'host'
SHOW GRANTS FOR jiajia2@'127.0.0.1';
3.给用户授权
语法:GRANT privileges ON databasename.tablename TO 'username'@'host'
- privileges:用户的操作权限,如
SELECT,INSERT,UPDATE
等,如果要授予所的权限则使用ALL,文章最后会介绍所有权限。 - databasename:数据库名
- tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*
-- 例如:
-- 给jiajia2用户添加test数据库中所有表的所有操作权限
GRANT ALL ON test.* TO jiajia2@'127.0.0.1';
-- 给jiajia2用户添加所有数据库中所有表的所有操作权限
GRANT ALL ON *.* TO jiajia2@'127.0.0.1';
用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
GRANT ALL ON test.* TO jiajia2@'127.0.0.1' WITH GRANT OPTION;
4.撤销用户权限
REVOKE ALL PRIVILEGES ON *.* FROM jiajia2@'127.0.0.1';
revoke 跟 grant 的语法差不多,只需要把关键字 “to” 换成 “from” 即可
假如你在给用户'test'@'%'
授权的时候是这样的(或类似的):
GRANT SELECT ON test.user TO 'test'@'%'
则在使用 REVOKE SELECT ON *.* FROM 'test'@'%';
命令并不能撤销该用户对test数据库中user表的SELECT 操作。
相反,如果授权使用的是GRANT SELECT ON *.* TO 'test'@'%';
则 REVOKE SELECT ON test.user FROM 'test'@'%';
命令也不能撤销该用户对test数据库中user表的Select权限。
具体信息可以用命令SHOW GRANTS FOR 'test'@'%';
查看。
5.刷新权限(每次修改权限都需要刷新)
flush privileges;
6.权限说明
权限 | 权限级别 | 权限说明 |
---|---|---|
CREATE | 数据库、表或索引 | 创建数据库、表或索引权限 |
DROP | 数据库或表 | 删除数据库或表权限 |
GRANT OPTION | 数据库、表或保存的程序 | 赋予权限选项 |
REFERENCES | 数据库或表 | |
ALTER | 表 | 更改表,比如添加字段、索引等 |
DELETE | 表 | 删除数据权限 |
INDEX | 表 | 索引权限 |
INSERT | 表 | 插入权限 |
SELECT | 表 | 查询权限 |
UPDATE | 表 | 更新权限 |
CREATE VIEW | 视图 | 创建视图权限 |
SHOW VIEW | 视图 | 查看视图权限 |
ALTER ROUTINE | 存储过程 | 更改存储过程权限 |
CREATE ROUTINE | 存储过程 | 创建存储过程权限 |
EXECUTE | 存储过程 | 执行存储过程权限 |
FILE | 服务器主机上的文件访问 | 文件访问权限 |
CREATE TEMPORARY TABLES | 服务器管理 | 创建临时表权限 |
LOCK TABLES | 服务器管理 | 锁表权限 |
CREATE USER | 服务器管理 | 创建用户权限 |
RELOAD | 服务器管理 | 执行flush-hosts, flush-logs, flush-privileges, flush-status, flush-tables, flush-threads, refresh, reload等命令的权限 |
PROCESS | 服务器管理 | 查看进程权限 |
REPLICATION CLIENT | 服务器管理 | 复制权限 |
REPLICATION SLAVE | 服务器管理 | 复制权限 |
SHOW DATABASES | 服务器管理 | 查看数据库权限 |
SHUTDOWN | 服务器管理 | 关闭数据库权限 |
SUPER | 服务器管理 | 执行kill线程权限 |
权限分布 | 可能的设置的权限 |
---|---|
表权限 | ‘Select’, ‘Insert’, ‘Update’, ‘Delete’, ‘Create’, ‘Drop’, ‘Grant’, ‘References’, ‘Index’, ‘Alter’ |
列权限 | ‘Select’, ‘Insert’, ‘Update’, ‘References’ |
过程权限 | ‘Execute’, ‘Alter Routine’, ‘Grant’ |