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

相关推荐
TDengine (老段)15 分钟前
TDengine Rust 连接器进阶指南
大数据·数据库·物联网·rust·时序数据库·tdengine·涛思数据
二哈喇子!20 分钟前
MySQL数据库操作命令【SQL语言】
数据库·sql·视图与索引
China_Yanhy23 分钟前
AWS S3 深度配置指南:每一栏每个选项有什么作用
java·数据库·aws
yong999026 分钟前
基于MATLAB的大变形悬臂梁求解程序
前端·数据库·matlab
施嘉伟29 分钟前
Oracle SQL Profile 固化执行计划实战说明
数据库·sql·oracle
Dr.Alex Wang33 分钟前
Google Firebase 实战教学 - Streamlit、Bucket、Firebase
数据库·python·安全·googlecloud
万物得其道者成43 分钟前
用 Python + MySQL + Web 打造我的私有 Apple 设备监控面板
前端·python·mysql
程序 代码狂人1 小时前
SQL-速查表:NULL 相关函数对比
数据库·sql
kaico20181 小时前
MYSQL的日志文件
数据库·mysql
oMcLin1 小时前
如何在AlmaLinux 9上优化MariaDB Galera Cluster,提升数据库集群的事务一致性与并发处理能力?
数据库·mariadb