用户权限管理,把好数据库的第一道门

本文涉及的产品
PolarClaw,2核4GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 数据库小学妹带你轻松掌握MySQL权限管理!通过创建用户、授/回收权限(GRANT/REVOKE)、设置安全边界(localhost/%/IP段)和最小权限原则,实现角色分离与事前防护。牢记FLUSH PRIVILEGES刷新生效,告别root滥用,守好数据大门!

📌 今日关键词:权限分配、安全边界、角色管理

大家好呀!我是数据库小学妹👋

前面我们学会了各种数据库操作,但有个问题我一直隐隐担心:

我现在一直用 root 账号连接数据库,什么都能删、什么都能改。万一哪天猫踩键盘把生产数据清空了怎么办?或者同事需要查数据,我该不该把 root 密码告诉他?

数据库早就想到了这个问题——它提供了用户权限管理,就像给不同的人配不同的钥匙:有人只能开门(查数据),有人能开保险柜(删数据),有人只能进仓库(连某个库)。

如果说昨天我们学的​备份是“事后补救”​,那今天要学的​权限管理就是“事前防御”​!接下来我就把自己学会的用户权限管理分享出来,让你也能把好数据库的大门。

一、为什么必须学会权限管理?

1️⃣ 明确边界,防止“乱入”

  • 保护敏感数据: 比如用户密码、财务信息等,不能随便让人看。
  • 避免误操作: 限制普通用户的权限,防止“手滑”删表、改数据。
  • 职责分离: 开发、测试、运维各司其职,不同角色权限不同,减少风险。

2️⃣ 权限 = 数据库的“门禁卡”

通过精细化的权限分配,我们可以决定:

  • 谁(用户/角色)能访问数据库。
  • 能访问哪些数据库或表。
  • 能做什么(查询、插入、修改、删除等操作)。

🛠️ 新手必会:权限管理实操(MySQL命令)

权限管理核心命令只有几个,但组合起来非常灵活!就像给数据库“发门禁卡” 🆔。

二、用户管理:创建、修改、删除

1. 查看当前所有用户

SELECT user, host FROM mysql.user;

host 表示允许从哪个IP连接:localhost 只能本机,% 表示任意IP。

2. 创建用户

CREATE USER '用户名'@'主机' IDENTIFIED BY '密码';

示例​:

-- 允许本地连接
CREATE USER 'xiaomei'@'localhost' IDENTIFIED BY '123456';

-- 允许任意IP连接(生产环境慎用)
CREATE USER 'xiaomei'@'%' IDENTIFIED BY '123456';

-- 允许指定IP段
CREATE USER 'xiaomei'@'192.168.1.%' IDENTIFIED BY '123456';

3. 修改密码

-- 方法1:用 ALTER USER(推荐)
ALTER USER 'xiaomei'@'localhost' IDENTIFIED BY 'newpass';

-- 方法2:用 SET PASSWORD(老语法)
SET PASSWORD FOR 'xiaomei'@'localhost' = 'newpass';

4. 删除用户

DROP USER 'xiaomei'@'localhost';

三、权限管理:授予、查看、回收

1. 授予权限(GRANT)

GRANT 权限列表 ON 数据库.表 TO '用户名'@'主机';

常见权限​:

权限 作用
ALL PRIVILEGES 所有权限(除GRANT OPTION外)
SELECT 查询数据
INSERT 插入数据
UPDATE 更新数据
DELETE 删除数据
CREATE 创建表/库
DROP 删除表/库
INDEX 创建/删除索引
EXECUTE 执行存储过程

实战示例​:

-- 让 xiaomei 只能查 mydb 库里的所有表
GRANT SELECT ON mydb.* TO 'xiaomei'@'localhost';

-- 让 xiaoming 可以查和插入 mydb 里的 orders 表
GRANT SELECT, INSERT ON mydb.orders TO 'xiaoming'@'localhost';

-- 让 xiaoli 拥有 mydb 库的所有权限(但不能给别人授权)
GRANT ALL PRIVILEGES ON mydb.* TO 'xiaoli'@'localhost';

2. 刷新权限(重要!)

修改权限后,执行以下命令让权限立即生效:

FLUSH PRIVILEGES;

3. 查看用户权限

-- 查看当前用户的权限
SHOW GRANTS;

-- 查看指定用户的权限
SHOW GRANTS FOR 'xiaomei'@'localhost';

4. 回收权限(REVOKE)

-- 回收 xiaomei 的 INSERT 权限
REVOKE INSERT ON mydb.* FROM 'xiaomei'@'localhost';

-- 回收所有权限
REVOKE ALL PRIVILEGES ON mydb.* FROM 'xiaomei'@'localhost';

四、权限的生效级别(由粗到细)

级别 写法 说明
全局 *.* 所有数据库的所有表
数据库级 mydb.* 指定数据库的所有表
表级 mydb.orders 指定数据库的指定表
列级 mydb.orders (name, price) 只允许操作某些列(较少用)

💡 ​新手建议​:

  • 优先用数据库级权限,平衡安全性和灵活性。
  • `.*​*\** 代表所有库所有表,慎用!例如GRANT ALL ON *.* TO ...` 是超级权限(类似 root)。
  • 生产环境建议最小权限原则:“给需要的,而不是给所有的”。

五、实战:创建三个不同权限的用户

假设我们有一个电商数据库 shop,包含 usersordersproducts 三张表。

用户 职责 需要的权限
reader 数据分析师 只读所有表
writer 订单录入员 对 orders 表 INSERT、UPDATE
admin 数据库管理员 对 shop 库的所有权限
-- 1. 创建只读用户
CREATE USER 'reader'@'localhost' IDENTIFIED BY 'read123';
GRANT SELECT ON shop.* TO 'reader'@'localhost';

-- 2. 创建订单写入用户
CREATE USER 'writer'@'localhost' IDENTIFIED BY 'write123';
GRANT SELECT, INSERT, UPDATE ON shop.orders TO 'writer'@'localhost';

-- 3. 创建管理员用户(但不能给别人授权)
CREATE USER 'admin'@'localhost' IDENTIFIED BY 'admin123';
GRANT ALL PRIVILEGES ON shop.* TO 'admin'@'localhost';

FLUSH PRIVILEGES;

之后,每个人用自己的账号登录,就只能做权限范围内的事。

六、新手避坑指南(血泪总结)

常见错误 正确做法
创建用户时没指定host,导致只能从%连接 明确指定'user'@'localhost''user'@'192.168.%'
授权后忘记FLUSH PRIVILEGES 必须刷新,否则权限不生效
给用户授予了ALL PRIVILEGES但没有GRANT OPTION 用户无法给自己或其他用户授权,这是安全的
删用户时没指定 host,可能删错 SHOW GRANTS确认,再用DROP USER 'user'@'host'
生产环境用'user'@'%'允许任意IP连接 只开放必要IP,如'user'@'192.168.1.100'

七、今日学习心得

今天的内容总结成三句话:

  1. 永远不要用root做日常操作​,创建专用用户并只给最小权限
  2. GRANT 和 REVOKE 是权限管理的核心,学会数据库级和表级授权
  3. FLUSH PRIVILEGES 一定要记得,不然改了等于没改

👋 我是数据库小学妹一个用设计师思维学数据库的转行人。我们一起,把复杂的技术变得简单有趣!💕

本文为个人学习总结,所有命令均在MySQL 8.0环境下验证。权限管理是生产环境的第一道防线,一定要重视。

相关文章
|
20天前
|
人工智能 数据可视化 安全
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)
本文详解如何用阿里云Lighthouse一键部署OpenClaw,结合飞书CLI等工具,让AI真正“动手”——自动群发、生成科研日报、整理知识库。核心理念:未来软件应为AI而生,CLI即AI的“手脚”,实现高效、安全、可控的智能自动化。
34899 55
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)
|
15天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)
本文介绍了Claude Code终端AI助手的使用指南,主要内容包括:1)常用命令如版本查看、项目启动和更新;2)三种工作模式切换及界面说明;3)核心功能指令速查表,包含初始化、压缩对话、清除历史等操作;4)详细解析了/init、/help、/clear、/compact、/memory等关键命令的使用场景和语法。文章通过丰富的界面截图和场景示例,帮助开发者快速掌握如何通过命令行和交互界面高效使用Claude Code进行项目开发,特别强调了CLAUDE.md文件作为项目知识库的核心作用。
13874 42
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)
|
3天前
|
缓存 人工智能 自然语言处理
我对比了8个Claude API中转站,踩了不少坑,总结给你
本文是个人开发者耗时1周实测的8大Claude中转平台横向评测,聚焦Claude Code真实体验:以加权均价(¥/M token)、内部汇率、缓存支持、模型真实性及稳定性为核心指标。
|
10天前
|
人工智能 JavaScript Ubuntu
低成本搭建AIP自动化写作系统:Hermes保姆级使用教程,长文和逐步实操贴图
我带着怀疑的态度,深度使用了几天,聚焦微信公众号AIP自动化写作场景,写出来的几篇文章,几乎没有什么修改,至少合乎我本人的意愿,而且排版风格,也越来越完善,同样是起码过得了我自己这一关。 这个其实OpenClaw早可以实现了,但是目前我觉得最大的区别是,Hermes会自主总结提炼,并更新你的写作技能。 相信就冲这一点,就值得一试。 这篇帖子主要就Hermes部署使用,作一个非常详细的介绍,几乎一步一贴图。 关于Hermes,无论你赞成哪种声音,我希望都是你自己动手行动过,发自内心的选择!
2789 28
|
1月前
|
人工智能 JSON 机器人
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw
本文带你零成本玩转OpenClaw:学生认证白嫖6个月阿里云服务器,手把手配置飞书机器人、接入免费/高性价比AI模型(NVIDIA/通义),并打造微信公众号“全自动分身”——实时抓热榜、AI选题拆解、一键发布草稿,5分钟完成热点→文章全流程!
45813 158
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw
|
5天前
|
弹性计算 人工智能 自然语言处理
阿里云Qwen3.6全新开源,三步完成专有版部署!
Qwen3.6是阿里云全新MoE架构大模型系列,稀疏激活显著降低推理成本,兼顾顶尖性能与高性价比;支持多规格、FP8量化、原生Agent及100+语言,开箱即用。
|
8天前
|
人工智能 弹性计算 安全
Hermes Agent是什么?怎么部署?超详细实操教程
Hermes Agent 是 Nous Research 于2026年2月开源的自进化AI智能体,支持跨会话持久记忆、自动提炼可复用技能、多平台接入与200+模型切换,真正实现“越用越懂你”。MIT协议,部署灵活,隐私可控。
2120 4