单用户多角色权限的MSSQL实现
来源:互联网 发布:哪里可以注册域名 编辑:程序博客网 时间:2024/06/04 19:42
数据表设计
分为用户表、角色表、角色拥有权限表、权限表、用户所属角色表
表名:Users(用户表)
字段 类型 长度 说明 ID int 自动编号,主键 UserName varchar 20 Password varchar 20
表名:Roles(角色表)
字段 类型 长度 说明 ID int 自动编号,主键 Name varchar 50
表名:UsersRoles(用户所属角色表)
字段 类型 长度 说明 ID int 自动编号,主键 UserID int 对Users.ID做外键 RoleID int 对Roles.ID做外键
表名:Permissions(权限表)
字段 类型 长度 说明 ID int 自动编号,主键 Name varchar 50 权限的名称
表名:RolesPermissions(角色权限表)
字段 类型 长度 说明 ID int 自动编号,主键 RoleID int 对Roles.ID做外键 PermissionID int 对Permissions.ID做外键 Allowed small int 该权限是否被允许
完成后的关系图如下所示:
以下的存储过程用于检查用户@UserName是否拥有名称为@Permission的权限
CREATE Procedure CheckPermission
(
@UserName varchar(20),
@Permission varchar(50)
)
AS
SELECT MIN(Allowed) FROM RolesPermissions
INNER JOIN Permissions ON Permissions.ID = PermissionID
INNER JOIN Roles ON Roles.ID = RoleID
INNER JOIN UsersRoles ON UsersRoles.ID = Roles.ID
INNER JOIN Users ON Users.ID = UsersRoles.UserID
WHERE Users.UserName=@UserName AND Permissions.Name=@Permission
单用户多角色权限的原理
假设用户A现在同时有两个角色Programmer和Contractor的权限
- 单用户多角色权限的MSSQL实现
- 单用户多角色权限的MSSQL实现
- 单用户多角色权限的MSSQL实现
- 单用户多角色权限的MSSQL实现
- mssql 授予角色权限
- 用户多角色权限的实现
- shiro实现基于角色的权限授权
- MSSQL 数据库修复,语句参考及单用户模式的处理
- MSSQL db_owner角色注入直接获得系统权限- -
- MSSQL db_owner角色注入直接获得系统权限
- 我的角色权限
- Oracle的权限、角色
- resource角色的权限
- ASP.net MVC 基于角色的权限控制系统的实现
- J2EE学习笔记(5) 角色权限资源管理的实现
- Acegi+hibernate 动态实现基于角色的权限管理
- Acegi+hibernate 动态实现基于角色的权限管理
- Acegi+hibernate 动态实现基于角色的权限管理
- 微软再批iPhone不支持Office 称不适合企业用户
- 有关SESSION丢失的原因
- 做自己的二级域名指向系统
- 网站二级域名用.net 2.0实现方案
- H.264概述与MPEG-X的区别
- 单用户多角色权限的MSSQL实现
- vs2003下vcDLL与c#之间的通讯
- Alexa工具条嵌入浏览器技术解析
- test
- JAVA集合的认识
- [文档]02_项目开发计划(省略)
- java--基本数据类型与对应的包装类
- 我决定今天我不想加班!
- 新手找不到门?