通用权限管理设计篇(二)——数据库设计
2015-05-14 17:54
85 查看
让我们接着来进行数据库的设计。在数据库建模时,对于N对N的关系,一般需要加入一个关联表来表示关联的两者的关系。初步估计一下,本系统至少需要十张表,分别为:权限表、用户表、角色表、组表、用户权限关联表、用户角色关联表、角色权限关联表、组权限关联表、组角色关联表、用户属组关联表。当然还可能引出一些相关的表。下面让我们在PowerDesigner中画出各表吧。
各表及其关系如下:
![](http://www.blogjava.net/images/blogjava_net/amigoxie/21128/r_%e6%9c%aa%e5%91%bd%e5%90%8d.bmp)
1. 用户表
2. 角色表
3. 权限表
4. 组表
5. 角色权限表
6. 组权限表
7. 组角色表
8. 用户权限表
9. 用户角色表
10. 用户组表
11. 组织表
12. 操作日志表
各表及其关系如下:
![](http://www.blogjava.net/images/blogjava_net/amigoxie/21128/r_%e6%9c%aa%e5%91%bd%e5%90%8d.bmp)
1. 用户表
用户表(TUser) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tu_id | bigint | pk, not null |
所属组织 | to_id | bigint | fk, not null |
登录帐号 | login_name | varchar(64) | not null |
用户密码 | password | varchar(64) | not null |
用户姓名 | vsername | varchar(64) | not null |
手机号 | mobile | varchar(20) | |
电子邮箱 | email | varchar(64) | |
创建时间 | gen_time | datetime | not null |
登录时间 | login_time | datetime | |
上次登录时间 | last_login_time | datetime | |
登录次数 | count | bigint | not null |
角色表(TRole) | |||
字段名称 | 字段 | 类型 | 备注 |
角色ID | tr_id | bigint | pk, not null |
父级角色ID | parent_tr_id | bigint | not null |
角色名称 | role_name | varchar(64) | not null |
创建时间 | gen_time | datetime | not null |
角色描述 | description | varchar(200) |
权限表(TRight) | |||
字段名称 | 字段 | 类型 | 备注 |
权限ID | tr_id | bigint | pk, not null |
父权限 | parent_tr_id | bigint | not null |
权限名称 | right_name | varchar(64) | not null |
权限描述 | description | varchar(200) |
组表(TGroup) | |||
字段名称 | 字段 | 类型 | 备注 |
组ID | tg_id | bigint | pk, not null |
组名称 | group_name | varchar(64) | not null |
父组 | parent_tg_id | bigint | not null |
创建时间 | gen_time | datetime | not null |
组描述 | description | varchar(200) |
角色权限表(TRoleRightRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | trr_id | bigint | pk, not null |
角色 | Role_id | bigint | fk, not null |
权限 | right_id | bigint | fk, not null |
权限类型 | right_type | int | not null(0:可访问,1:可授权) |
组权限表(TGroupRightRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tgr_id | bigint | pk, not null |
组 | tg_id | bigint | fk, not null |
权限 | tr_id | bigint | fk, not null |
权限类型 | right_type | int | not null(0:可访问,1:可授权) |
组角色表(TGroupRoleRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tgr_id | bigint | pk, not null |
组 | tg_id | bigint | fk, not null |
角色 | tr_id | bigint | pk, not null |
用户权限表(TUserRightRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tur_id | bigint | pk, not null |
用户 | tu_id | bigint | fk, not null |
权限 | tr_id | bigint | fk, not null |
权限类型 | right_type | int | not null(0:可访问,1:可授权) |
用户角色表(TUserRoleRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tur_id | bigint | pk, not null |
用户 | tu_id | bigint | fk, not null |
角色 | tr_id | bigint | fk, not null |
用户组表(TUserGroupRelation) | |||
字段名称 | 字段 | 类型 | 备注 |
记录标识 | tug_id | bigint | pk, not null |
用户 | tu_id | bigint | fk, not null |
组 | tg_id | bigint | fk, not null |
组织表(TOrganization) | |||
字段名称 | 字段 | 类型 | 备注 |
组织id | to_id | bigint | pk, not null |
父组 | parent_to_id | bigint | not null |
组织名称 | org_name | varchar(64) | not null |
创建时间 | gen_time | datetime | not null |
组织描述 | description | varchar(200) |
操作日志表(TLog) | |||
字段名称 | 字段 | 类型 | 备注 |
日志ID | log_id | bigint | pk, not null |
操作类型 | op_type | int | not null |
操作内容 | content | varchar(200) | not null |
操作人 | tu_id | bigint | fk, not null |
操作时间 | gen_time | datetime | not null |
相关文章推荐
- 通用权限管理设计篇(二)——数据库设计
- 通用权限管理设计篇(二)——数据库设计
- 通用权限管理设计篇(二)——数据库设计
- 数据库设计主意事项
- 数据库分类设计之分段分类编码法
- 数据库设计--三大范式
- 数据库设计范式(转)
- 项目小结之数据库设计
- 怎么设计一个好的数据库
- 所思所想 数据库设计技巧
- java数据库设计中的14个技巧
- 开发宝典:数据库设计技巧
- 【转】推荐:全面了解数据库设计中分类算法
- 树形结构的数据库表Schema设计
- 数据库扩展性设计:使用二进制解决一条记录关联多个状态的问题
- 数据库设计准则(第一、第二、第三范式说明)
- 转 举例说明数据库设计中的三个范式
- 关系数据库的几种设计范式介绍
- ASP.NET 系统支持数据库访问设计
- 数据库设计范式(实例)