基于数据库的权限系统设计

基于数据库的权限系统设计

ID:23507045

大小:902.31 KB

页数:25页

时间:2018-11-08

基于数据库的权限系统设计_第1页
基于数据库的权限系统设计_第2页
基于数据库的权限系统设计_第3页
基于数据库的权限系统设计_第4页
基于数据库的权限系统设计_第5页
资源描述:

《基于数据库的权限系统设计》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、这一天将讲述一个基本的基于数据库的权限管理系统的设计,在这一天的课程的最后将讲述“左右值无限分类实现算法”如何来优化“系统菜单”的结构而告终。今天的内容和前几天的基础框架是一样的它们都属于基础知识,在这些基础知识上还可以扩展出无数的变种与进化设计。二、先来看客户的一个需求2.1用户实际需求1.       所有的用户、角色可动态配置2.       所有的系统菜单的权限要求具体到“增,删,改、查、打印、导出”这样的小权限的设计3.       所有的权限基于角色来进行划分和判断4.       一个用户可能属于多个角色5

2、.       系统菜单也能够动态的“增、删、改、查”2.2系统权限菜单样例三、基于数据库的系统权限表设计3.1ER(EntityRelationship)图围绕上述需求,我们可以在数据库内进行如下的表设计,下面直接给出ER图:3.2表关系详解上述设计有6张表,其中:T_User表用于存放用户信息,此处只存放基础信息T_Role表用于存放系统角色信息T_User_Role表用于存放系统用户与角色的匹配关系T_Sys_Menu表这张就是用于存放系统菜单的表了,这张表的设计主要使用了如下的表设计技巧:注意这边的MENU_ID

3、与MENU_PID如果这个菜单项是一级菜单,那么我们把它的MENU_PID设为0如果这个菜单是另一个菜单的子菜单,那么我们就把它的MENU_PID设为它的父菜单的MENU_ID。有了这样的结构,我们一个递归就能把这颗“树”显示出来了,是不是?此处以Oracle数据库为例,不使用递归,直接把树形结构在数据库中就造型造好(当然,还有更好的方法如:有人喜欢设level或者是deep这样的字段来简化程序解析树型结构菜单,稍后我们会来讲一个根本不需要用递归的树型菜单的设计来最大程度优化设计。)显示整颗树型菜单结构的Oracle语句

4、:SELECT*FROMT_SYS_MENUSTARTWITHMENU_PID=0CONNECTBYPRIORMENU_ID=MENU_PIDorderbyMENU_ID上述语句,已经用数据查询用句就将我们的这个“树”的层次关系理出来了,如果我们手上有一个控件叫dtree.js,那么一个循环就可以把这个树显示出来了,不是吗?来看dtree.js的应用//公式: d.add(menu_id,menu_pid,‘menudescr’,‘menu_url’);d=newdTree('d');                  

5、d.add(0,-1,'菜单');                  d.add(1,0,'报表查询','example01.html');                  d.add(2,1,'月报','example01.html');                  d.add(3,1,'季报','example01.html');                  d.add(4,1,'年报','example01.html');                  d.add(5,0,'系统管理','exam

6、ple01.html');                  d.add(6,5,'用户管理','example01.html');                  d.add(7,6,'新增用户','example01.html');                  d.add(8,6,'删除用户','example01.html');            d.add(9,5,'角色管理','example01.html');                  d.add(10,9,'新增角色','example

7、01.html');                  d.add(11,9,'删除角色','example01.html')                  document.write(d);大家看上面,这个是dtree.js插件,一个专门用于生成树的js插件的使用方法,那么如果我们附以上述的sql语句在数据库中把数据选出来后,是不是只要一个循环就可以给这个dtree.js插件显示了,不是吗?我们如果不想显示整颗树只想显示如:只显示系统管理菜单有其下列所有的子菜单,那么我们的Oracle中的Sql应该怎么写呢?经查

8、“系统管理”这个菜单的MENU_ID=’105’,于是我们的Sql语句如下:SELECT*FROMT_SYS_MENUSTARTWITHMENU_ID='105'CONNECTBYPRIORMENU_ID=MENU_PIDorderbyMENU_ID对吧?很简单哈!T_Privilege表用于存放系统每个菜单的详细子

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。