权限五张表
重点:权限五张表的设计
核心概念:
在权限管理系统中,经典的设计通常涉及五张表,分别是用户表、角色表、权限表、用户角色表和角色权限表。这五张表的设计可以有效地管理用户的权限,确保系统的安全性和灵活性。
- 用户(User):系统的使用者,每个用户有唯一的身份标识。
- 角色(Role):一组权限的集合,用于简化权限分配。
- 权限(Permission):系统中具体的操作或资源访问权限(如读取、写入、删除等)。
- 用户角色关联:将用户与角色关联起来,表示用户拥有某个角色的权限。
- 角色权限关联:将角色与权限关联起来,表示角色拥有哪些权限。
表之间的关系
-
用户与角色:
- 一个用户可以有多个角色,一个角色可以分配给多个用户。
- 通过
user_role表实现多对多关系。
-
角色与权限:
- 一个角色可以有多个权限,一个权限可以分配给多个角色。
- 通过
role_permission表实现多对多关系。
-
权限层级:
- 用户通过角色间接拥有权限。
- 查询用户权限时,需要先查询用户所属角色,再查询角色对应的权限。

1.表设计
1.1 用户表(user)
- 用户表用于存储系统中的用户信息,包括用户ID、用户名和用户密码等。每个用户在登录时都会通过该表进行验证,以确保其合法性。
CREATE TABLE `user` (`id` INT PRIMARY KEY AUTO_INCREMENT,`username` VARCHAR(50) NOT NULL UNIQUE,`password` VARCHAR(255) NOT NULL,`email` VARCHAR(100),`active` TINYINT(1) NOT NULL DEFAULT 1,`version` INT NOT NULL DEFAULT 0,`created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,`updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
1.2 角色表(role)
- 角色表用于定义系统中的各种角色,例如管理员、普通用户等。每个角色代表一组权限,用户通过分配角色来获得相应的权限。
CREATE TABLE `role` (`id` INT PRIMARY KEY AUTO_INCREMENT,`name` VARCHAR(50) NOT NULL UNIQUE,`description` VARCHAR(255),`active` TINYINT(1) NOT NULL DEFAULT 1,`version` INT NOT NULL DEFAULT 0,`created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,`updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
1.3 权限表(permission)
- 权限表用于存储系统中的各种资源和操作,例如页面访问、按钮点击等。每个权限项描述了一个具体的操作,用户只有拥有相应的权限才能执行该操作。
CREATE TABLE `permission` (`id` INT PRIMARY KEY AUTO_INCREMENT,`name` VARCHAR(50) NOT NULL UNIQUE,`description` VARCHAR(255),`active` TINYINT(1) NOT NULL DEFAULT 1,`version` INT NOT NULL DEFAULT 0,`created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,`updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
1.4 用户角色关联表(user_role)
- 用户角色表用于建立用户与角色之间的关系。通过该表,可以将用户分配到不同的角色,从而获得相应的权限。
CREATE TABLE `user_role` (`user_id` INT NOT NULL,`role_id` INT NOT NULL,`active` TINYINT(1) NOT NULL DEFAULT 1,`version` INT NOT NULL DEFAULT 0,`created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,`updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`user_id`, `role_id`),FOREIGN KEY (`user_id`) REFERENCES `user`(`id`),FOREIGN KEY (`role_id`) REFERENCES `role`(`id`)
);
1.5 角色权限关联表(role_permission)
- 角色权限表用于建立角色与权限之间的关系。通过该表,可以为每个角色分配不同的权限,从而实现用户到角色,角色到权限的转换。
CREATE TABLE `role_permission` (`role_id` INT NOT NULL,`permission_id` INT NOT NULL,`active` TINYINT(1) NOT NULL DEFAULT 1,`version` INT NOT NULL DEFAULT 0,`created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,`updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`role_id`, `permission_id`),FOREIGN KEY (`role_id`) REFERENCES `role`(`id`),FOREIGN KEY (`permission_id`) REFERENCES `permission`(`id`)
);
2.实现案例
场景:学生管理系统中有管理员、教师、学生三种角色。
- 管理员可以管理所有数据。
- 教师可以管理学生成绩。
- 学生只能查看自己的成绩。
2.1 查询用户的角色
SELECT r.name
FROM `user` u
JOIN `user_role` ur ON u.id = ur.user_id
JOIN `role` r ON ur.role_id = r.id
WHERE u.username = 'test_user' AND u.active = 1 AND r.active = 1;
2.2 查询用户的权限
SELECT p.name AS permission_name
FROM user u
JOIN user_role ur ON u.id = ur.user_id
JOIN role_permission rp ON ur.role_id = rp.role_id
JOIN permission p ON rp.permission_id = p.id
WHERE u.username = 'student1';
2.3 查询所有教师角色
SELECT u.username
FROM user u
JOIN user_role ur ON u.id = ur.user_id
JOIN role r ON ur.role_id = r.id
WHERE r.name = 'teacher';
2.4 逻辑删除用户
UPDATE `user` SET active = 0 WHERE id = 1;
2.5 使用乐观锁更新用户信息
UPDATE user
SET email = 'new_teacher1@test.com', version = version + 1
WHERE username = 'teacher1' AND version = 0; -- 假设当前版本号为0
MySQL中的权限五张表(了解,选择性观看!)
1. 了解MySQL权限系统
MySQL通过权限系统控制用户对数据库、表、列等的访问权限。权限信息存储在mysql数据库的五张表中:user、db、tables_priv、columns_priv、procs_priv。这些表是层级关系,MySQL在检查权限时从上到下依次检查。
SELECT * FROM mysql.user WHERE User = 'test_user';

2.权限五张表
表1:user 表
-
作用:存储全局权限,即用户对所有数据库的权限。在任一数据库中都可以使用
-
关键字段:
Host:允许用户连接的主机(如localhost、%)。User:用户名。权限字段:如Select_priv、Insert_priv、Update_priv等,表示用户是否拥有对应的全局权限。Grant_priv:用户是否可以授权其他用户权限
-
示例:
SELECT Host, User, Select_priv, Insert_priv FROM mysql.user WHERE User = 'test_user';解释:这条查询会显示用户
test_user在所有数据库上的SELECT和INSERT权限。
表2:db 表
-
作用:
- 存储用户对特定数据库的权限。
- 如果用户在
user表中没有全局权限,MySQL会检查db表,判断用户是否有权限访问某个数据库。
-
关键字段:
Host、User:与user表相同。Db:数据库名称。权限字段:如Select_priv、Insert_priv等,表示用户在该数据库上的权限。
-
示例:
SELECT Host, User, Db, Select_priv, Insert_priv FROM mysql.db WHERE User = 'test_user';解释:这条查询会显示用户
test_user在test_db数据库上的权限。
表3:tables_priv 表
-
作用:存储用户对特定表的权限。
-
关键字段:
Host、User、Db:与db表相同。Table_name:表名称。Table_priv:用户在该表上的权限(如Select、Insert等)。Column_priv:用户在该表的列上的权限(如果有)。
-
示例:
SELECT Host, User, Db, Table_name, Table_priv FROM mysql.tables_priv WHERE User = 'test_user';解释:这条查询会显示用户
test_user在test_db.test_table表上的权限。
表4:columns_priv 表
-
作用:存储用户对特定列的权限。
-
关键字段:
Host、User、Db、Table_name:与tables_priv表相同。Column_name:列名称。Column_priv:用户在该列上的权限(如Select、Insert等)。
-
示例:
SELECT Host, User, Db, Table_name, Column_name, Column_priv FROM mysql.columns_priv WHERE User = 'test_user';解释:这条查询会显示用户
test_user在test_db.test_table表中特定列上的权限。
表5:procs_priv 表
-
作用:
- 存储用户对存储过程和函数的权限。
- 如果用户需要执行存储过程或函数,MySQL会检查
procs_priv表。
-
关键字段:
Host、User、Db:与db表相同。Routine_name:存储过程或函数的名称。Routine_type:类型(PROCEDURE或FUNCTION)Proc_priv:用户对该存储过程或函数的权限(如Execute)。
-
示例:
SELECT Host, User, Db, Routine_name, Routine_type, Proc_priv FROM mysql.procs_priv WHERE User = 'test_user';解释:这条查询会显示用户
test_user在test_db数据库中存储过程和函数上的权限。
3.权限检查流程
- MySQL在检查用户权限时,按照以下顺序检查:
- 检查
user表中的全局权限。 - 检查
db表中的数据库权限。 - 检查
tables_priv表中的表权限。 - 检查
columns_priv表中的列权限。 - 检查
procs_priv表中的存储过程和函数权限。
- 检查
- **注意:**如果某一层级的权限满足要求,MySQL就不会继续检查下一层级。
相关文章:
权限五张表
重点:权限五张表的设计 核心概念: 在权限管理系统中,经典的设计通常涉及五张表,分别是用户表、角色表、权限表、用户角色表和角色权限表。这五张表的设计可以有效地管理用户的权限,确保系统的安全性和灵活性。 用户&…...
Docker-数据卷
1.数据卷 容器是隔离环境,容器内程序的文件、配置、运行时产生的容器都在容器内部,我们要读写容器内的文件非常不方便。大家思考几个问题: 如果要升级MySQL版本,需要销毁旧容器,那么数据岂不是跟着被销毁了࿱…...
在Linux系统下修改Docker的默认存储路径
在Linux系统下修改Docker的默认存储路径可以通过多种方法实现,下边是通过修改daemon.json文件方式实现 查看当前Docker存储路径 使用命令 docker info | grep "Docker Root Dir" 查看当前Docker的存储路径,默认为 /var/lib/docker 停止Docker…...
IT : 是工作還是嗜好? Delphi 30周年快乐!
又到2月14日了, 自从30多年前收到台湾宝蓝(Borland)公司一大包的3.5 磁盘片, 上面用黑色油性笔写着Delphi Beta开始, Delphi便和我的工作生涯有了密不可分的关系. 一年后Delphi大获成功, 自此对于使用Delphi的使用者来说2月14日也成了一个特殊的日子! 我清楚记得Delphi Beta使用…...
DeepPose
目录 摘要 Abstract DeepPose 算法框架 损失函数 创新点 局限性 训练过程 代码 总结 摘要 DeepPose是首个将CNN应用于姿态估计任务的模型。该模型在传统姿态估计方法的基础上,通过端到端的方式直接从图像中回归出人体关键点的二维坐标,避免了…...
[HarmonyOS]鸿蒙(添加服务卡片)推荐商品 修改卡片UI(内容)
什么是服务卡片 ? 鸿蒙系统中的服务卡片(Service Card)就是一种轻量级的应用展示形式,它可以让用户在不打开完整应用的情况下,快速访问应用内的特定功能或信息。以下是服务卡片的几个关键点: 轻量级&#…...
DeepSeek R1 本地部署和知识库搭建
一、本地部署 DeepSeek-R1,是幻方量化旗下AI公司深度求索(DeepSeek)研发的推理模型 。DeepSeek-R1采用强化学习进行后训练,旨在提升推理能力,尤其擅长数学、代码和自然语言推理等复杂任务 。 使用DeepSeek R1, 可以大大…...
领域驱动设计叕创新,平安保险申请DDD专利
DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 见下图: 这个名字拼得妙:领域驱动设计模式。 是领域驱动设计?还是设计模式?还是领域驱动设计设计模式?和下面这个知乎文章的…...
团体程序设计天梯赛-练习集——L1-041 寻找250
前言 10分的题,主要的想法就一个,按这个想法可以出几个写法 L1-041 寻找250 对方不想和你说话,并向你扔了一串数…… 而你必须从这一串数字中找到“250”这个高大上的感人数字。 输入格式: 输入在一行中给出不知道多少个绝对值…...
动量突破均值回归策略
动量突破均值回归策略:量化交易中的双剑合璧 引言 在量化交易的世界中,动量策略和均值回归策略是两种经典且广泛应用的策略。动量策略基于“强者恒强”的理念,认为过去表现良好的资产在未来一段时间内仍会继续表现良好;而均值回…...
vue3.x 的provide 与 inject详细解读
在 Vue 3.x 中,provide 和 inject 是一对用于实现依赖注入的 API。它们允许父组件向其所有子组件(无论嵌套多深)传递数据或方法,而不需要通过 props 逐层传递。这在开发复杂组件或高阶组件时非常有用。 1. provide 的基本用法 p…...
C#控制台大小Console.SetWindowSize函数失效解决
在使用C#修改控制台大小相关API会失效. 由于VS将控制台由命令提示符变成了终端,因此在设置大小时会出现问题 测试代码: Console.SetWindowSize(100, 50);...
spring boot 对接aws 的S3 服务,实现上传和查询
1.aws S3介绍 AWS S3(Amazon Simple Storage Service)是亚马逊提供的一种对象存储服务,旨在提供可扩展、高可用性和安全的数据存储解决方案。以下是AWS S3的一些主要特点和功能: 1.1. 对象存储 对象存储模型:S3使用…...
25/2/16 <算法笔记> DirectPose
DirectPose 是一种直接从图像中预测物体的 6DoF(位姿:6 Degrees of Freedom)姿态 的方法,包括平移和平面旋转。它在目标检测、机器人视觉、增强现实(AR)和自动驾驶等领域中具有广泛应用。相比于传统的位姿估…...
数据结构-8.Java. 七大排序算法(下篇)
本篇博客给大家带来的是排序的知识点, 由于时间有限, 分两天来写, 下篇主要实现最后一种排序算法: 归并排序。同时把中篇剩下的快排非递归实现补上. 文章专栏: Java-数据结构 若有问题 评论区见 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是…...
缓存穿透、缓存击穿、缓存雪崩的区别与解决方案
1. 缓存穿透(Cache Penetration) 定义:大量请求查询 数据库中不存在的数据,导致请求绕过缓存直接访问数据库,造成数据库压力过大。 场景: 恶意攻击:例如用不存在的用户ID频繁请求。 业务误操作…...
DeepSeek私有化部署+JAVA通过API调用离线大模型问答
在当今快速发展的数字化时代,企业对于高效、灵活的技术解决方案需求日益增长。DeepSeek作为一款领先的智能搜索与分析平台,凭借其强大的数据处理能力和精准的搜索结果,已经成为众多企业提升运营效率的得力助手。为了更好地满足企业对数据安全…...
【go语言规范】Gopherfest 2015 | Go Proverbs with Rob Pike的 总结
根据 Gopherfest 2015 | Go Proverbs with Rob Pike 的演讲,总结内容如下: 虽然已是十年前的产物,但是proverbs的价值依旧存在 以下是整合补充内容后的完整总结,涵盖 Rob Pike 在 Gopherfest 2015 演讲 “Go Proverbs” 中的核心…...
【吾爱出品】针对红警之类老游戏适用WIN10和11的补丁cnc-ddraw7.1汉化版
针对红警之类老游戏适用WIN10和11的补丁cnc-ddraw7.1汉化版 链接:https://pan.xunlei.com/s/VOJ8PZd4avMubnDzHQAeZDxWA1?pwdnjwm# 直接复制到游戏安装目录,保持与游戏主程序同目录下。...
内容中台驱动企业数字化内容管理高效协同架构
内容概要 在数字化转型加速的背景下,企业对内容管理的需求从单一存储向全链路协同演进。内容中台作为核心支撑架构,通过统一的内容资源池与智能化管理工具,重塑了内容生产、存储、分发及迭代的流程。其核心价值在于打破部门壁垒,…...
【第14章:神经符号集成与可解释AI—14.4 神经符号集成与可解释AI的未来发展趋势与挑战】
想象一下,如果AI既能像人类一样直觉感知(比如一眼认出街角的咖啡店),又能像数学家一样逻辑推理(比如计算最优路线避开拥堵),这个世界会变成什么样?这种“双脑协同”正是神经符号集成技术的终极目标。 但现实是,当前99%的AI系统要么只会“死记硬背”数据(如深度学习模…...
[JVM篇]虚拟机性能监控、故障处理工具
虚拟机性能监控、故障处理工具 基础故障处理工具 jps(JVM Peocess Status Tool - 虚拟机进程状况工具) jstat(JVM Statistics Monitoring Too - 虚拟机统计信息监视工具) jinfo( Configuration info for Java - Java配置信息工具) jmap(Memory Map for…...
Ubuntu 下 nginx-1.24.0 源码分析 - ngx_cycle_t 类型
ngx_cycle_t 定义在 src/core/ngx_core.h typedef struct ngx_cycle_s ngx_cycle_t; ngx_cycle_s 定义在 src/core/ngx_cycle.h struct ngx_cycle_s {void ****conf_ctx;ngx_pool_t *pool;ngx_log_t *log;ngx_log_t …...
WHERE子句中的条件
在SQL查询中,WHERE子句用于指定筛选条件,以限制从数据库表中检索出的数据行。WHERE子句通常位于SELECT、UPDATE、DELETE等SQL语句中,紧跟在FROM子句(对于SELECT语句)或其他相关子句之后。 一、WHERE子句的基本语法 sq…...
Effective Objective-C 2.0 读书笔记——内存管理(下)
Effective Objective-C 2.0 读书笔记——内存管理(下) 在 dealloc 方法中只释放引用并解除监听 对象在经历其生命期后 ,最终会为系统所回收 ,这时就要执行dealloc 方法了。 在每个对象的生命期内,此方法仅执行一次&a…...
[Spring Boot] Expense API 实现
[Spring Boot] Expense API 实现 项目地址:expense-api 项目简介 最近跟着视频做的一个 spring boot 的项目,包含了比较简单的记账功能的实现(只限 API 部分),具体实现的功能有: 记账(expen…...
Pell数列【一本通在线评测】
目录 描述 输入描述 输出描述 用例输入 1 用例输出 1 什么是pell数列 一、定义与递推关系 二、数学性质 三、应用领域 四、编程实现要点 五、扩展与相关概念 C代码实现 描述 Pell数列a1,a2,a3,...的定义是这样的,a11,a22,...,an2an−1a…...
linux ollama deepseek等大语言模型的model文件的存储目录
linux ollama deepseek等大语言模型的model文件的存储目录 一、用ollama serve启动的,模型数据存放在: /usr/share/ollama/.ollama/models二、如果在自启动文件中指定了工作目录,则在工作目录下的.ollama/models 1.自启动服务 /etc/system…...
【PyQt】工具栏(QToolBar)与动作按钮(QAction)使用指南
PyQt工具栏(QToolBar)与动作按钮(QAction)使用指南 🛠️ 一、基础用法示例 🌟 class MainWindow(QMainWindow):def __init__(self):super().__init__()# 创建工具栏 🔧self.toolbar self.addToolBar("主工具栏")# 创建动作集合 …...
软路由折腾 | OpenWrt安装后基础配置指南:联网设置与DNS优化
在PVE中安装OpenWrt教程 一、网络基础配置 1. 确认网络接口角色 OpenWrt旁路由通常仅需配置LAN口,无需WAN口。其流量通过主路由转发,因此需确保: 物理连接:OpenWrt的LAN口(如eth0)桥接到主路由的局域网&…...
