【mysql】设置mysql数据库只读权限用户

目录

1、方法1:创建用户并授予特定数据库的只读权限(推荐)

2、方法2:创建用户并授予所有数据库的只读权限(谨慎使用)

2.1关键参数说明:

[2.2 验证权限:](#2.2 验证权限:)

[2.3 安全建议:](#2.3 安全建议:)


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

要在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;

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 安全建议:

  1. 最小权限原则:只授予必要的数据库权限

  2. 访问限制

    • 生产环境建议用 'user'@'192.168.1.%' 限制IP段

    • 远程访问时用 'user'@'%' 但需配置防火墙

  3. 密码策略

    复制代码
    ALTER USER 'readonly_user'@'%' 
    WITH PASSWORD EXPIRE INTERVAL 90 DAY;  -- 强制90天修改密码
  4. 撤销权限(如果需要):

    复制代码
    REVOKE SELECT ON your_database_name.* FROM 'readonly_user'@'%';
    DROP USER 'readonly_user'@'%';
    复制代码

⚠️ 注意:执行脚本需具有 CREATE USERGRANT OPTION 权限的管理员账户。

相关推荐
元闰子2 分钟前
怎么让程序更高效地连起来?
数据库·redis·mysql
洲覆6 分钟前
Redis 内存淘汰策略
开发语言·数据库·redis·缓存
胖头鱼的鱼缸(尹海文)35 分钟前
数据库管理-第376期 Oracle AI DB 23.26新特性一览(20251016)
数据库·人工智能·oracle
麦聪聊数据37 分钟前
浅谈SQL审核(一):SQL审核实现方式与常见工具的选择
数据库·sql
ajassi200044 分钟前
开源 Linux 服务器与中间件(七)数据库--MySQL
linux·服务器·数据库·ubuntu·开源
韩立学长1 小时前
【开题答辩实录分享】以《自然灾害隐患点管理信息系统》为例进行答辩实录分享
数据库·spring boot
迎風吹頭髮1 小时前
Linux服务器编程实践58-getnameinfo函数:通过socket地址获取主机名与服务名
开发语言·数据库·php
christine-rr1 小时前
linux常用命令——其他
linux·服务器·网络·数据库·redis·ubuntu
一只专注api接口开发的技术猿2 小时前
容器化与调度:使用 Docker 与 K8s 管理分布式淘宝商品数据采集任务
开发语言·前端·数据库
tryxr2 小时前
MySQL 之索引为什么选择B+树
数据库·mysql·b+树·索引