0

0

mysql中表与列的访问权限控制方法

P粉602998670

P粉602998670

发布时间:2026-01-12 10:56:03

|

934人浏览过

|

来源于php中文网

原创

MySQL表级权限用GRANT SELECT ON db.table授予,列级权限需括号指定字段如GRANT SELECT(name,phone) ON db.users;权限叠加生效但列级会收窄范围,已存连接不自动更新权限。

mysql中表与列的访问权限控制方法

MySQL 中如何给用户授予表级权限

直接用 GRANT 指定数据库和表名即可,权限作用范围精确到 db_name.table_name。不加表名(如 db_name.*)是库级;加了就是表级。

常见错误:误以为 GRANT SELECT ON db_name.* TO 'u'@'h' 能限制到某张表——它实际允许访问该库下所有表。

  • 只允许查 orders 表:
    GRANT SELECT ON myapp.orders TO 'reporter'@'192.168.1.%';
  • 允许多个操作(INSERT/UPDATE)但仅限 logs 表:
    GRANT INSERT, UPDATE ON myapp.logs TO 'logger'@'localhost';
  • 执行后必须 FLUSH PRIVILEGES; 才生效(仅在直接操作 mysql 系统表后才强制需要,常规 GRANT 一般不用)

列级权限怎么设:只让看某些字段

MySQL 支持列级 SELECTINSERTUPDATE 权限,但不支持 DELETEREFERENCES 的列级控制。语法是在 GRANT 后用括号列出列名。

典型场景:客服只能看到用户表的 namephone,不能查 id_cardpassword_hash

LOVESTUdio多校园网络店铺
LOVESTUdio多校园网络店铺

主要更新介绍: 完美整合Discuz!论坛,实现一站式登陆、退出、注册; 同步所有会员资料; 新增购物车功能,商品购买更加方便、快捷; 新增部分快捷菜单,网站访问更加方便; 限制首页商品、店铺标题显示长度; 修正会员后台管理不能更改密码的错误; 完善商品显示页面所有功能链接; 修正后台标签管理部分错误; 修正前台学校列表不按后台顺序显示的错误; 修正搜索功能中学校名称过长导致显示紊乱的现象; 修正

下载
  • 只授权读两列:
    GRANT SELECT (name, phone) ON myapp.users TO 'cs_agent'@'%';
  • 插入时只允许填部分字段:
    GRANT INSERT (username, email, created_at) ON myapp.users TO 'app_writer'@'10.0.0.%';
  • UPDATE 列权限要求更严格:如果某用户只有 UPDATE (status) 权限,连 UPDATE status = 'done' WHERE id = 123 都会报错——因为 WHERE 里用了未授权的 id

权限冲突时谁生效:表级 vs 列级

MySQL 权限检查是“叠加式”的:只要任意一级(列、表、库、全局)授予了某权限,且没有被显式 REVOKE,该权限就有效。但列级权限不会覆盖表级限制,而是进一步收窄可操作范围。

例如:GRANT SELECT ON myapp.users TO 'u'@'h' + GRANT SELECT (email) ON myapp.users TO 'u'@'h',最终效果等同于只授权 email 列——因为列级 SELECT 会隐式撤销其他列的访问权。

  • 不能混用矛盾授权:先给全表 SELECT,再给单列 SELECT,后者会生效;但反过来(先列后全表),全表授权会覆盖列级限制
  • REVOKE 必须匹配原授权粒度:用列级 GRANT 授的权,就得用列级 REVOKE 撤,否则撤不掉
  • 查看当前用户的列级权限:查 mysql.columns_priv 表,注意 is_active 字段是否为 Y

权限变更后连接不生效?注意连接复用和缓存

MySQL 用户权限在服务端内存中缓存,新连接会立即读取最新权限,但已存在的连接不会自动刷新。这是最常被忽略的“改了权限却没用”的原因。

  • 应用使用连接池时,旧连接可能持续数小时,期间权限修改完全无效
  • 验证方法:用 SHOW GRANTS FOR 'user'@'host'; 在目标连接中执行,确认看到的是预期权限
  • 强制重载权限(极少需手动):FLUSH PRIVILEGES;,但日常运维中应避免依赖它——优先让应用重建连接
  • 列级权限对 INFORMATION_SCHEMA.COLUMNS 无影响,用户仍能看到所有列名,只是查数据时被拦截

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

660

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

245

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

528

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

598

2023.08.14

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

3

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号