zoukankan      html  css  js  c++  java
  • TP支持菜单动态生成RBAC权限系统数据库结构设计方案

    最简单基于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');  
  • 相关阅读:
    使用webdriver出现的问题:[18796:1808:0730/131103.313:ERROR:install_util.cc(600)] Failed to read HKLMSOFTWAREPoliciesGoogleChromeMachineLevelUserCloudPolicyEnrollmentToken: 系统找不到指定的文件。 (0x2) DevTools lis
    1130 host is not allowed to connect to
    Mysql误删了root用户怎么办
    猫眼电影爬取
    sklearn之聚类的均值漂移算法
    sklearn之聚类K均值算法
    基于支持向量机的分类模型和回归模型案例
    超参数处理之网格搜素
    redis基础之有序集合应用
    Sklearn之支持向量机分类
  • 原文地址:https://www.cnblogs.com/kingfly/p/4156636.html
Copyright © 2011-2022 走看看