惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Attack and Defense Labs
Attack and Defense Labs
The GitHub Blog
The GitHub Blog
C
Check Point Blog
博客园_首页
MongoDB | Blog
MongoDB | Blog
N
Netflix TechBlog - Medium
F
Full Disclosure
Microsoft Security Blog
Microsoft Security Blog
爱范儿
爱范儿
Recent Announcements
Recent Announcements
阮一峰的网络日志
阮一峰的网络日志
G
GRAHAM CLULEY
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
T
Threat Research - Cisco Blogs
C
Cybersecurity and Infrastructure Security Agency CISA
V
Vulnerabilities – Threatpost
K
Kaspersky official blog
博客园 - 司徒正美
S
Schneier on Security
T
The Exploit Database - CXSecurity.com
Project Zero
Project Zero
云风的 BLOG
云风的 BLOG
Cisco Talos Blog
Cisco Talos Blog
Know Your Adversary
Know Your Adversary
雷峰网
雷峰网
V
V2EX - 技术
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Spread Privacy
Spread Privacy
罗磊的独立博客
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
S
Security Affairs
SecWiki News
SecWiki News
Schneier on Security
Schneier on Security
O
OpenAI News
Jina AI
Jina AI
PCI Perspectives
PCI Perspectives
Cyberwarzone
Cyberwarzone
Y
Y Combinator Blog
Apple Machine Learning Research
Apple Machine Learning Research
B
Blog RSS Feed
I
InfoQ
D
Docker
P
Palo Alto Networks Blog
Recorded Future
Recorded Future
M
MIT News - Artificial intelligence
博客园 - Franky
B
Blog
Scott Helme
Scott Helme
博客园 - 叶小钗
D
DataBreaches.Net

博客园 - 王翔(kingfly)

IT技术团队行而有效的管理之道 九宫格抽奖HTML+JS版 Nginx负载均衡深入浅出 PHP 二维数组根据某个字段排序 MYSQL INSERT INTO SELECT 不插入重复数据 小米2成功使用google组件的办法(为了coc游戏能登录google账户) PHP 数组排序方法总结 普通标和转让标的回款和还款日期的算法。 thinkphp 关联模型配置代码 THinkphp开启静态(动态)缓存的用法 left join、right join、inner join的区别 Mysql字符串字段中是否包含某个字符串,用 find_in_set ThinkPHP Where 条件中使用表达式 通过递归组合多维数组! Thinkphp 关联模型和试图模型区别 执行一条SQL语句,插入多条数据! rtrim() 函数 从字符串的末端开始删除空白字符! 在Thinkphp中【自动加载自定义扩展配置文件】! Thinkphp的S缓存用法!
TP支持菜单动态生成RBAC权限系统数据库结构设计方案
王翔(kingfly) · 2014-12-11 · via 博客园 - 王翔(kingfly)
最简单基于RBAC权限系统数据库结构设计  
  
  
  
包括如下几个表  
  
1. 用户表  
  
  
-- Table "t_user" DDL  
  
CREATE TABLE `t_user` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `username` varchar(100) DEFAULT NULL,  
  `password` varchar(100) DEFAULT NULL,  
  `name` varchar(100) DEFAULT NULL,  
  `status` int(11) DEFAULT '0',  
  `department_id` int(11) DEFAULT NULL,  
  `desc` varchar(255) DEFAULT NULL,  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
  
2. 权限表  
  
  
-- Table "t_permission" DDL  
  
CREATE TABLE `t_permission` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `name` varchar(100) DEFAULT NULL,  
  `desc` varchar(255) DEFAULT NULL,  
  `status` int(11) DEFAULT NULL,  
  `is_menu_display` int(11) DEFAULT NULL,  
  `menu_url` varchar(255) DEFAULT NULL,  
  `main_menu_id` int(11) DEFAULT NULL,  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
  
3. 角色表  
  
  
-- Table "t_role" DDL  
  
CREATE TABLE `t_role` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `name` varchar(100) DEFAULT NULL,  
  `desc` varchar(200) DEFAULT NULL,  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
4. 用户角色表  
  
  
-- Table "t_user_role" DDL  
  
CREATE TABLE `t_user_role` (  
  `user_id` int(11) NOT NULL DEFAULT '0',  
  `role_id` int(11) NOT NULL DEFAULT '0',  
  PRIMARY KEY (`user_id`,`role_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
5. 角色权限表  
  
  
-- Table "t_role_permission" DDL  
  
CREATE TABLE `t_role_permission` (  
  `role_id` int(11) NOT NULL DEFAULT '0',  
  `permission_id` int(11) NOT NULL DEFAULT '0',  
  PRIMARY KEY (`role_id`,`permission_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
6. 菜单表  
  
  
-- Table "t_menu" DDL  
  
CREATE TABLE `t_menu` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `name` varchar(100) DEFAULT NULL,  
  `desc` varchar(255) DEFAULT NULL,  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
7. 部门表  
  
  
-- Table "t_department" DDL  
  
CREATE TABLE `t_department` (  
  `id` int(11) NOT NULL AUTO_INCREMENT,  
  `name` varchar(100) DEFAULT NULL,  
  `desc` varchar(255) DEFAULT NULL,  
  PRIMARY KEY (`id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
  
  
涉及的主要sql:  
  
  
1. 获取某个用户的权限列表:   
  
  select * from t_permission where id in (select distinct permission_id  from t_role_permission where role_id in ( select role_id  from t_user_role where user_id=1))  
  
2. 主菜单列表:(菜单)  
  
select * from t_menu where id in (  
select distinct main_menu_id from t_permission where id in (1,2,3,4))  
  
  
  
3. 某个主菜单下的子菜单列表:  
  
   select * from t_permission where id in (1,2,3,4) and   main_menu_id=1  
  
   select * from t_permission where id in (1,2,3,4) and   main_menu_id=2

测试数据:

INSERT INTO `t_department` VALUES ('1', '技术部', '技术部');  
INSERT INTO `t_department` VALUES ('2', '财务部', '财务部');  
INSERT INTO `t_department` VALUES ('3', '设计部', '设计部');  
INSERT INTO `t_menu` VALUES ('1', '系统管理', '系统管理');  
INSERT INTO `t_menu` VALUES ('2', '财务管理', '财务管理');  
INSERT INTO `t_menu` VALUES ('3', '部门管理', '部门管理');  
INSERT INTO `t_menu` VALUES ('4', '日志管理', '日志管理');  
INSERT INTO `t_menu` VALUES ('5', '角色管理', '角色管理');  
INSERT INTO `t_permission` VALUES ('1', '用户列表', '用户列表', '0', '1', 'userlist.do', '1');  
INSERT INTO `t_permission` VALUES ('2', '用户新增', '用户新增', '0', '1', 'useradd.do', '1');  
INSERT INTO `t_permission` VALUES ('3', '用户修改', '用户修改', '0', '1', 'userModify.do', '1');  
INSERT INTO `t_permission` VALUES ('4', '用户删除', '用户删除', '0', '1', 'userDel.do', '2');  
INSERT INTO `t_permission` VALUES ('5', '用户查询', '用户查询', '0', '1', 'userSearch.do', '3');  
INSERT INTO `t_role` VALUES ('1', '系统管理员', '系统管理员');  
INSERT INTO `t_role` VALUES ('2', '测试角色1', '测试角色1');  
INSERT INTO `t_role` VALUES ('3', '测试角色2', '测试角色2');  
INSERT INTO `t_role_permission` VALUES ('1', '1');  
INSERT INTO `t_role_permission` VALUES ('1', '2');  
INSERT INTO `t_role_permission` VALUES ('1', '3');  
INSERT INTO `t_role_permission` VALUES ('2', '2');  
INSERT INTO `t_role_permission` VALUES ('3', '4');  
INSERT INTO `t_user` VALUES ('1', 'admin', 'admin', '管理员', '0', '1', '管理员');  
INSERT INTO `t_user_role` VALUES ('1', '1');  
INSERT INTO `t_user_role` VALUES ('1', '2');  
INSERT INTO `t_user_role` VALUES ('1', '3');