如何设置mysql数据库只读权限用户及全部权限
前言:
工作过程当中,如果开放你数据库的读写权限,怕引起安全问题或者数据被篡改。对方又要你数据库访问的读权限。

一、授予用户只读权限

要在MySQL中创建一个只能进行查询(SELECT)的用户,请使用以下脚本。根据你的MySQL版本和需求,有两种常见方法:
1、方法1:创建用户并授予特定数据库的只读权限(推荐)
-- 创建新用户(替换 'readonly_user' 和 'YourPassword123!') CREATE USER 'readonly_user'@'%' IDENTIFIED BY 'YourPassword123!'; -- 授予对指定数据库的 SELECT 权限(替换 your_database_name) GRANT SELECT ON your_database_name.* TO 'readonly_user'@'%'; -- 刷新权限使更改生效 FLUSH PRIVILEGES;
指定库名: GRANT SELECT, INSERT, UPDATE, DELETE, EXECUTE, SHOW VIEW
ON `库名`.*
TO 'sjzt'@'%'; -- 注意结尾必须有分号
2、方法2:创建用户并授予所有数据库的只读权限(谨慎使用)
-- 创建新用户(替换凭证) CREATE USER 'readonly_user'@'localhost' IDENTIFIED BY 'YourPassword123!'; -- 授予全局 SELECT 权限 GRANT SELECT ON *.* TO 'readonly_user'@'localhost'; FLUSH PRIVILEGES;
2.1关键参数说明:
| 参数 | 说明 |
|---|---|
'readonly_user'@'%' | 用户名 + 访问来源(%允许任意IP访问,localhost仅限本地) |
IDENTIFIED BY | 设置强密码(需包含字母、数字、特殊字符) |
your_database_name.* | 权限作用范围(替换为实际数据库名,如 sales_db.*) |
GRANT SELECT | 仅授权查询权限(无INSERT/UPDATE/DELETE等写权限) |
2.2 验证权限:
-- 查看用户权限 SHOW GRANTS FOR 'readonly_user'@'%';
输出应类似:
GRANT SELECT ON `your_database_name`.* TO `readonly_user`@`%`
2.3 安全建议:
最小权限原则:只授予必要的数据库权限
访问限制:
生产环境建议用
'user'@'192.168.1.%'限制IP段远程访问时用
'user'@'%'但需配置防火墙
密码策略:
ALTER USER 'readonly_user'@'%' WITH PASSWORD EXPIRE INTERVAL 90 DAY; -- 强制90天修改密码
撤销权限(如果需要):
REVOKE SELECT ON your_database_name.* FROM 'readonly_user'@'%'; DROP USER 'readonly_user'@'%';
⚠️ 注意:执行脚本需具有
CREATE USER和GRANT OPTION权限的管理员账户。
二、授予全部数据库权限
-- 创建用户 szt,密码为 aa1dd CREATE USER 'szt'@'%' IDENTIFIED BY 'aa1dd'; -- 授予 szt 用户对所有数据库的所有权限 GRANT ALL PRIVILEGES ON *.* TO 'szt'@'%'; -- 刷新权限使更改生效 FLUSH PRIVILEGES; -- # 验证 SHOW GRANTS FOR 'szt'@'%';
三、授予部分数据库读写权限
-- 创建用户 sk(需要您提供密码,这里暂时用 'password' 代替) CREATE USER 'sk'@'%' IDENTIFIED BY 'password'; -- 授予 sk 用户对 aa 数据库的所有权限 GRANT ALL PRIVILEGES ON `aa`.* TO 'sk'@'%'; -- 授予 sk 用户对 BB 数据库的所有权限 GRANT ALL PRIVILEGES ON `BB`.* TO 'sk'@'%'; -- 刷新权限使更改生效 FLUSH PRIVILEGES; -- 验证 SHOW GRANTS FOR 'sk'@'%';
总结
到此这篇关于如何设置mysql数据库只读权限用户及全部权限的文章就介绍到这了,更多相关mysql只读权限用户及全部权限内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Windows下MySQL5.6查找my.ini配置文件的方法
今天小编就为大家分享一篇Windows下MySQL5.6查找my.ini配置文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-06-06
MySQL 8.0.26版本升级32版本查询数据为空的解决方案
这篇文章主要介绍了MySQL 8.0.26版本升级32版本查询数据为空的跟踪,本文给大家分享两种解决方法,结合实例代码给大家介绍的非常详细,需要的朋友参考下吧2024-03-03
Mysql5.7忘记root密码及mysql5.7修改root密码的方法
这篇文章主要介绍了Mysql5.7忘记root密码及mysql5.7修改root密码的方法的相关资料,需要的朋友可以参考下2016-01-01
windows下mysql 8.0.16 安装配置方法图文教程
这篇文章主要为大家详细介绍了windows下mysql 8.0.16 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-05-05


最新评论