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

相关推荐
数据知道3 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707533 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha3 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_3 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance3 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋3 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.4 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82184 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
大巨头4 小时前
sql2008 数据库分页语句
数据库
m0_715575344 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python