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

相关推荐
ShadowSmartMicros2 小时前
java调用milvus数据库
java·数据库·milvus
Bug.ink2 小时前
BUUCTF——WEB(2)
数据库·sql·网络安全·buuctf
李慕婉学姐3 小时前
【开题答辩过程】以《基于PHP的动漫社区的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
开发语言·mysql·php
网硕互联的小客服3 小时前
Centos系统如何更改root账户用户名?需要注意什么?
linux·运维·服务器·数据库·安全
lisanmengmeng3 小时前
zentao的prod环境升级(一)
linux·运维·数据库·docker·容器·禅道
それども3 小时前
insertOnDuplicateKey 和 upsert 区别
数据库·mysql
nbsaas-boot3 小时前
SQL Server 存储过程设计规范(事务与异常处理)
linux·数据库·设计规范
大学生资源网3 小时前
基于springboot的万亩助农网站的设计与实现源代码(源码+文档)
java·spring boot·后端·mysql·毕业设计·源码
q_19132846954 小时前
基于SpringBoot2+Vue2的诗词文化传播平台
vue.js·spring boot·mysql·程序员·计算机毕业设计