



RBAC不用给用户单个分配权限,只用指向对应的角色就会有对应的权限,而且分配权限和收回权限都很方便

5个关系对应5张表



五张表设计
1 CREATE TABLE `user` (
2 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
3 `name` varchar(20) NOT NULL DEFAULT '' COMMENT '姓名',
4 `email` varchar(30) NOT NULL DEFAULT '' COMMENT '邮箱',
5 `is_admin` tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否是超级管理员 1表示是 0 表示不是',
6 `status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态 1:有效 0:无效',
7 `updated_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '最后一次更新时间',
8 `created_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间',
9 PRIMARY KEY (`id`),
10 KEY `idx_email` (`email`)
11 ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表';
12
13 CREATE TABLE `role` (
14 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
15 `name` varchar(50) NOT NULL DEFAULT '' COMMENT '角色名称',
16 `status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态 1:有效 0:无效',
17 `updated_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '最后一次更新时间',
18 `created_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间',
19 PRIMARY KEY (`id`)
20 ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='角色表';
21
22 CREATE TABLE `user_role` (
23 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
24 `uid` int(11) NOT NULL DEFAULT '0' COMMENT '用户id',
25 `role_id` int(11) NOT NULL DEFAULT '0' COMMENT '角色ID',
26 `created_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '插入时间',
27 PRIMARY KEY (`id`),
28 KEY `idx_uid` (`uid`)
29 ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户角色表';
30
31 CREATE TABLE `access` (
32 `id` int(11) unsigned NOT NULL
