Activiti开发案例之创建用户表视图实现关联查询


前言

在工作流中,最常用的就是待办任务列表了,如果你仅仅是通过 Activiti 自带的 API 进行查询,大多数情况下查询的数据会不准确。

案例

API:

//查询待办任务
taskService.createTaskQuery().taskCandidateOrAssigned(userId);

SQL:

首先查询用户所在组权限

SELECT
  g.*
FROM ACT_ID_GROUP g,
  ACT_ID_MEMBERSHIP membership
WHERE g.ID_ = membership.GROUP_ID_
    AND membership.USER_ID_ = ?

如果存在角色

SELECT DISTINCT
  RES.*
FROM ACT_RU_TASK RES
  LEFT JOIN ACT_RU_IDENTITYLINK I
    ON I.TASK_ID_ = RES.ID_
WHERE (RES.ASSIGNEE_ = ?
        OR (RES.ASSIGNEE_ IS NULL
            AND (I.USER_ID_ = ?
                  OR I.GROUP_ID_ IN(SELECT
                                      g.GROUP_ID_
                                    FROM ACT_ID_MEMBERSHIP g
                                    WHERE g.USER_ID_ = ?))))

如果此用户不存在角色,当然大部分情况都会存在

SELECT DISTINCT
  RES.*
FROM ACT_RU_TASK RES
  LEFT JOIN ACT_RU_IDENTITYLINK I
    ON I.TASK_ID_ = RES.ID_
WHERE (RES.ASSIGNEE_ = ?
        OR (RES.ASSIGNEE_ IS NULL
            AND (I.USER_ID_ = ?
                  AND I.GROUP_ID_  IS NULL )))

通过观察,相关SQL有关联 Activiti 自带用户信息表,如果业务用户信息没有同步到Activiti 用户信息表,是无法进行正确查询的。

方案

同步用户数据是不可能的,这辈子都不可能,这里推荐大家用视图覆盖同名的 ACT_ID_ 系列表。

简单的用户角色表,根据业务需求自行调整:

CREATE TABLE `sys_user` (
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `username` varchar(255) NOT NULL,
   `password` varchar(255) NOT NULL,
   `email` varchar(255) NOT NULL,
   `org_id` int(11) NOT NULL,
   PRIMARY KEY (`id`)
 ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
CREATE TABLE `sys_role` (
   `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
   `role_code` varchar(255) NOT NULL COMMENT '角色代码',
   `role_name` varchar(255) NOT NULL COMMENT '角色名称',
   PRIMARY KEY (`id`)
 ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
CREATE TABLE `sys_user_role` (
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `role_id` int(11) NOT NULL,
   `user_id` int(11) NOT NULL,
   PRIMARY KEY (`id`)
 ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8

创建视图:

-- 删除自带的用户信息表    

DROP TABLE `act_id_membership`;
DROP TABLE `act_id_group`;
DROP TABLE `act_id_user`;
 
-- 如果之前存在视图则删除
    
DROP VIEW  IF EXISTS act_id_membership;  
DROP VIEW  IF EXISTS act_id_user;  
DROP VIEW  IF EXISTS act_id_group;
 
-- 用户视图
 
CREATE OR REPLACE VIEW act_id_user  AS   
  SELECT  
    u.username AS ID_,  
    0          AS REV_,  
    u.username   AS FIRST_,  
    '' AS LAST_,  
    u.email      AS EMAIL_,  
    u.password   AS PWD_,  
    ''          AS PICTURE_ID_  
  FROM sys_user u;  

-- 角色实体
 
CREATE VIEW act_id_group   
AS  
  SELECT r.role_name AS ID_,
         NULL AS REV_,
         r.role_name AS NAME_,
         'assignment' AS TYPE_
  FROM sys_role r;  

-- 用户-角色对应视图

CREATE VIEW act_id_membership  
AS  
   SELECT user_id AS USER_ID_,
       (SELECT r.role_name FROM sys_role r WHERE r.id=ur.role_id) AS GROUP_ID_  
   FROM sys_user_role ur;

最后配置一下是否检测身份信息表:

# 检测身份信息表是否存在
spring.activiti.db-identity-used=false
爪哇笔记

作者: 小柒

出处: https://blog.52itstyle.vip

分享是快乐的,也见证了个人成长历程,文章大多都是工作经验总结以及平时学习积累,基于自身认知不足之处在所难免,也请大家指正,共同进步。

本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 如有问题, 可邮件(345849402@qq.com)咨询。