MySQL 指南:全面掌握用户管理与权限控制

在数据库管理中,安全性是重中之重。直接使用 root 用户操作生产环境数据库是极大的安全隐患。因此,学会如何创建普通用户、分配最小必要权限,是每一位后端开发和 DBA 的必修课。

本文将带你系统地梳理 MySQL 的用户管理体系。

目录 (Table of Contents)

1.用户管理

1.1用户信息

1.2用户创建

1.3删除用户

1.4修改密码

2.数据库的权限

2.1给用户授权

3.总结


1.用户管理

MySQL的用户账号和信息都储存再系统数据库mysql的user表中,我们对用户管理的本质上实际是对这个表进行操作,但是官方推荐使用专用的SQL指令(如 CREATER USER)而非直接修改表数据,以确保数据的一致性。

1.1用户信息

要查看数据库中有哪些用户,以及他们允许登录的主机,我们需要查询myslq的user表。

核心的字段说明

  • User: 用户名。

  • Host: 允许登录的主机地址。

    • localhost: 仅允许本地登录。

    • %: 通配符,允许从任意远程主机登录(生产环境慎用)。

    • 192.168.1.%: 允许该网段登录。

这里我们可以对USER表直接进行查询,其中包括了用户名以及用户权限的一大批属性。

也可以直查询需要的信息,比如:

USE mysql;

SELECT User, Host FROM user;

1.2用户创建

创建用户的时候需要显示指定用户名,允许用户登录的主机以及用户密码。

基本语法:

CREATE USER 'username'@'host' IDENTIFIED BY 'password';

实战示例:

创建本地开发用户(只能在服务器本机登录):

创建远端登录用户(允许任意IP链接,实际生产环境不推荐)

查user表两个用户都已经创建成功了

用刚创建的用户进行登录:

1.3删除用户

当某个用户不需要的时候就可以删除了

基本语法:

DROP USER 'username'@'host';

1.4修改密码

出于安全策略(如定期轮换密码)或密码泄露风险,我们需要修改用户密码。在 MySQL 5.7 和 8.0+ 版本中,推荐使用 ALTER USER 命令。

基本语法:

ALTER USER 'username'@'host' IDENTIFIED BY 'new_password';

修改当前用户登录的密码:

root修改用户密码:

2.数据库的权限

在数据库中某一个用户登录了mysql不代表着他能访问所有数据了,还需要root赋予他相应的权限才可以对数据库以及表做出相关操作,以下是MySQL数据库提高的权限列表:

刚创建的用户是没有任何权限的,需要root用户授权,否则它什么也干不了

2.1给用户授权

授权使用 GRANT 语句。你可以控制用户能访问哪些库、哪些表,甚至哪些列。

基本语法:

GRANT 权限列表 ON 数据库名.表名 TO 'username'@'host';

常用权限类型:

  • ALL PRIVILEGES: 所有权限(除 GRANT OPTION 外)。

  • SELECT, INSERT, UPDATE, DELETE: 数据操作权限。

  • CREATE, DROP, ALTER: 结构操作权限。

权限列表如果有多个权限需要用逗号分隔开。

1.授予只读权限 (适用于报表系统或分析员):

2.授予管理员权限(管理特定数据库),当前只有查看权限无法对数据库中的表做增删改的功能。

可以使用语法:

GRANT ALL PRIVILEGES ON test2.* TO 'toutie'@'localhost';

3.刷新权限

虽然现代版 MySQL 在 GRANT 后通常立即生效,但习惯上我们会执行以下命令确保权限刷新到内存:

FLUSH PRIVILEGES;

2.2回收权限

如果某个用户权限过大,或者在业务需要调整,我们需要回收部分或者全部权限。可以使用REVOKE语句。

查看当前权限: 在回收之前,最好先看看用户当前有什么权限:

SHOW GRANTS FOR 'username'@'host'

回收权限语法:

REVOKE 权限列表 ON 数据库名.表名 FROM 'username'@'host';

3.总结

做好 MySQL 的用户管理是保障数据安全的第一道防线。请务必记住以下原则:

  • 严禁 在代码中硬编码 root 账号。

  • 区分 localhost%,尽量限制特定 IP 访问。

  • 遵循最小权限原则 ,够用即可,不要滥用 ALL PRIVILEGES

相关推荐
倔强的石头_8 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端