MySQL 用户管理
admin
2023-05-28 12:21:14
0

合理的管理DB用户权限是一个DBA的基本工作,这里整理一下MySQL用户管理的相关内容。

CREATE USER、DROP USER、RENAME USER 
用来创建、删除、修改MySQL用户

GRANT 
为给定MySQL用户分配权限

REVOKE 撤销已给定MySQL用户的相关权限

SET PASSWORD 为MySQL用户配置密码

SHOW GRANTS 显示给定MySQL用户的权限 
相关用户及权限的信息都会记录在MySQL
数据库中的权限表中,如下: 
user 可连接到数据库的用户及其全局权限 
db 数据库级权限 
table_priv 数据表级权限 
columns_priv 数据列级权限 
procs_priv 与存储例成相关的权限

MySQL用户管理 
创建MySQL用户(拥有创建MySQL 用户权限的用户才可以创建,下面例子以root用户为
测试用户)

mysql> create user kevin@'%' identified by 'oracle';
Query OK, 0 rows affected (0.00 sec)mysql> select user, host, password from mysql.user where user='kevin';
+-------+------+-------------------------------------------+| user  | host | password                                  |
+-------+------+-------------------------------------------+| kevin | %    | *2447D497B9A6A15F2776055CB2D1E9F86758182F |
+-------+------+-------------------------------------------+1 row in set (0.00 sec)

kevin@’%’ 用户名+主机名 
% 字符通配符,表示任意字符 
MySQL通过配置主机名来限制通过索要创建的MySQL用户登录的主机,%表示任意主机都可以登入。 
kevin@10.8.1.% 表示10.8.1段的主机可以登入 
kevin@’
Oracle.com.cn’ 表示主机名为oracle.com.cn的主机可以通过kevin用户登入。

对MySQL账户授权 
syntax: 
GRANT privileges (columns) 
on what 
TO account 
[identified by ‘password’] 
[REQUIRE encryption requirements] 
[WITH grant or resource management options]

如果grant语句中账户不存在则先创建相应账户,再把给定权限分配给它。 
privilege 授予账户的权限。 
what 权限的级别。 最高级别是全局,给定的权限用于所有的数据库和所有的数据表。同时,权限还可以设置为数据库、表、列及存储过程级别。 
account 被授予权限的账号。 
password 修改账户的口令 
columns 权限作用列

REQUIRE和WITH子句是可选的,require子句用于使用SSL进行安全连接。WITH子句用来授予GRANT OPTION权限(允许把账户自己的权限授予别人)。

账户权限整理 
数据库管理权限 
CREATE USER FILE(READ OR WRITE MYSQL SERVER’S FILES) GRANT OPTION RELOAD PROCESS REPLICATION CLIENT REPLICATION SLAVE SHUTDOWN SUPER(kill command to shutdown processes or other super user operation) 
数据库对象权限 
ALTER/ALTER ROUTINE/CREATE/CREATE ROUTINE/CREATE TEMPORARY TABLES/CREATE VIEWS/DELETE/DRPOP/EVENT/EXECUTE/INDEX/INSERT/LOCK TABLES/REFERENCE/SELECT/SHOW VIEW/TRIGGER/UPDATE 
其它权限 
ALL ALL operations inluding GRANT privilege 
USAGE a special privilege and means NULL privilege

用户在授权时必须拥有相应的权限及GRANT OPTION权限。同时,MySQL权限范围包括数据库系统全局,数据库,数据表,数据列等多种范围,付权时通过ON子句控制赋予权限的范围,如下: 
ON . 全局权限 
ON * 如果没有指定数据库(use db),则是全局权限,否则是是定数据库默认对象的权限。 
ON db_name.* 数据库级别权限 
ON db_name.tbl_name 数据库表级权限 
ON tbl_name 数据表级权限 
ON db_name。routie_name 存储例程权限

查看用户拥有的权限。

mysql> show grants for system;
+----------------------------------------------------------------------------------------------------------------+| Grants for system@%                                                                                            |
+----------------------------------------------------------------------------------------------------------------+| GRANT ALL PRIVILEGES ON *.* TO 'system'@'%' IDENTIFIED BY PASSWORD '*58319282EAB9E38D49CA25844B73DA62C80C2ABC' |
+----------------------------------------------------------------------------------------------------------------+1 row in set (0.00 sec)12345671234567

撤销权限和删除用户 
REVOKE privileges [columns] ON what FROM account;

修改用户的口令 
SET PASSWORD FOR system@’%’ = PASSWORD(‘PASSWD’)

当然,增加、修改用户的权限也可以直接insert、update mysql.user表,这些操作就需要感性却的初学者试一下了。


相关内容

热门资讯

杨宝桢“宣布退出民众党”,独立... 杨宝桢昨(20)日宣布退出民众党,独立参选台中市东南区市议员选举。前民众党发言人杨宝桢有意角逐台中市...
司法部谈“饭店后厨装不装挡鼠板... ‍‍5月21日,国务院新闻办公室举行新闻发布会,介绍规范涉企行政执法专项行动有关情况。“‘执法标准不...
耿同学,一个退学博士是怎么用A... 2026年的春夏之交,中国学术圈和文学圈接连经历了两场“地震”。学术圈的震中,是一个叫“耿同学讲故事...
国网河南电力智能计量技术亮相2... 5月20日,第 27 个“世界计量日”中国主场活动在河南郑州举行。国网河南省电力公司展示的具身智能机...
原创 手... 上半年换新机的最好时间就是618。为了冲击销量,手机厂家会准备很多促销措施,包括发新机、降价,比如小...
中国汽车崛起,关于设计也该有一... 上个月的北京车展,在181台首发新车和71台概念车的集中呈现之下,汽车设计再次成为行业关注的焦点。 ...
又一大厂裁员8000人!员工连... 智东西 编译 | 佳扬 编辑 | 云鹏 智东西5月20日消息,据纽约时报报道,Meta 8000人裁...
三星罢工危机暂解,加薪6.2%... 三星电子在最后关头与工会达成初步协议,避免了一场可能严重冲击全球内存芯片供应链的大规模罢工。对于正处...
马办与调查小组撕破脸,李德维称... 马英九指控基金会前执行长萧旭岑、王光慈破坏财政纪律,并指派基金会董事组成三人小组调查,但基金会数度指...
潮涌伊滨向“新”行 魏书生中学的“AI创想家”未来教室。伊滨宣供图钢制家具智能化生产场景。张若含 摄宁德时代洛阳基地。张...