当前位置: 首页 > article >正文

芋道视频199 - 工作流 - 数据流转图 - ruoyi-vue-pro

1. 工作流引擎与Ruoyi-Vue-Pro的深度整合在Ruoyi-Vue-Pro项目中工作流引擎扮演着业务流程自动化的核心角色。以请假流程为例从员工提交申请到领导审批再到HR备案整个流程涉及多角色协作和状态流转。Flowable作为底层引擎通过ACT_RU_运行时和ACT_HI_历史两大系列数据表驱动流程运转。实际开发中我发现Ruoyi-Vue-Pro对原生Flowable做了三层关键扩展表单扩展层通过bpm_form表实现动态表单配置与ACT_RE_MODEL中的流程模型绑定审批规则层bpm_task_assign_rule表支持灵活的任务分配策略实例扩展层bpm_process_instance_ext表补充业务相关字段// 典型流程启动代码示例 BpmProcessInstanceCreateReqDTO createReqDTO new BpmProcessInstanceCreateReqDTO(); createReqDTO.setProcessDefinitionKey(leave_approval); createReqDTO.setFormVariables(Map.of(days,3,reason,病假)); Long instanceId bpmProcessInstanceService.createProcessInstance(createReqDTO);2. 从数据视角解析请假流程全生命周期2.1 流程发起阶段的数据轨迹当员工提交请假申请时系统会产生如下数据记录运行时表ACT_RU_TASK生成待办任务领导审批ACT_RU_VARIABLE存储表单变量请假天数、事由等ACT_RU_EXECUTION记录流程执行路径历史表ACT_HI_PROCINST创建流程实例记录ACT_HI_TASKINST初始化第一个任务节点扩展表bpm_process_instance_ext补充申请人、部门等业务字段实测发现一个易错点表单变量会同时在ACT_RU_VARIABLE和ACT_HI_VARINST产生记录但后者在流程结束后仍保留。2.2 审批阶段的数据联动领导审批通过时数据库发生连锁反应ACT_RU_TASK中原任务状态更新ACT_HI_TASKINST记录审批人和审批时间新建ACT_RU_TASK条目指向HR审批节点bpm_task_ext表记录审批意见-- 审批操作触发的典型SQL UPDATE ACT_RU_TASK SET ASSIGNEE_ hr001, CLAIM_TIME_ NOW() WHERE ID_ task123; INSERT INTO ACT_HI_COMMENT (TYPE_, USER_ID_, TASK_ID_, PROC_INST_ID_, MESSAGE_) VALUES (approval, leader01, task123, proc456, 同意);3. Flowable核心表结构深度剖析3.1 运行时表的关键作用ACT_RU_*表组就像流程的工作内存我总结其特点高频率更新任务状态、变量值随时变化临时性强流程结束后自动清理查询密集待办列表、任务处理等核心功能依赖这些表特别要注意ACT_RU_EXECUTION和ACT_RU_TASK的关联关系当流程没有分支时两者通常是一对一关系出现并行网关时则可能一对多。3.2 历史表的数据价值ACT_HI_*表组构成了流程的黑匣子具有审计价值保留完整的操作记录统计价值支持流程耗时分析恢复价值异常中断后可追溯在项目中我常用这个查询分析流程效率SELECT PROC_DEF_ID_, AVG(DURATION_) as avg_duration FROM ACT_HI_PROCINST GROUP BY PROC_DEF_ID_;4. Ruoyi-Vue-Pro的扩展表设计精妙之处4.1 业务字段扩展方案原生Flowable表只保留引擎必要字段Ruoyi通过三张核心扩展表弥补不足bpm_process_definition_ext添加分类、图标等展示字段bpm_process_instance_ext增加业务状态、结果等字段bpm_task_ext补充审批结果、原因等字段这种设计既保持引擎纯净又满足业务需求。我在实现加签功能时就是通过扩展表记录附加审批人信息。4.2 表单与流程的绑定机制Ruoyi采用智能绑定策略静态表单直接关联bpm_form表的ID动态表单通过formType10标识自定义表单配置create/view路径!-- 流程模型中表单绑定示例 -- userTask idleaderVerify name领导审批 flowable:formFieldValidationtrue extensionElements flowable:formProperty idcomment name审批意见 typestring/ /extensionElements /userTask5. 实战中的性能优化技巧经过多个项目实践我总结出以下优化要点5.1 数据库层面为ACT_HI_TASKINST添加复合索引 (ASSIGNEE_, END_TIME_)定期归档历史数据到统计库调整Flowable的异步执行器线程池大小5.2 查询优化避免在循环中查询ACT_RU_TASK使用ProcessInstanceQuery代替原生SQL对高频访问的流程变量添加缓存// 优化后的待办查询示例 ListTask tasks taskService.createTaskQuery() .taskAssignee(userId) .includeProcessVariables() // 一次获取变量 .orderByTaskCreateTime().desc() .listPage(0, 20);5.3 扩展表使用建议在bpm_process_instance_ext中添加常用查询字段为审批记录建立单独的归档表重要操作记录双写到业务日志表6. 常见问题排查指南6.1 流程卡住怎么办检查ACT_RU_TASK是否有对应任务查询ACT_RU_EXECUTION的IS_ACTIVE_字段验证ACT_RU_VARIABLE中的流程变量6.2 审批人丢失问题排查bpm_task_assign_rule表的分配规则检查ACT_RU_IDENTITYLINK的关联关系验证用户组数据同步机制6.3 历史数据异常我遇到过ACT_HI_PROCINST中DURATION_为负值的情况最终发现是服务器时区配置错误导致时间计算异常。建议统一使用UTC时间存储。7. 开发调试实用技巧7.1 可视化跟踪工具使用Flowable Modeler查看运行流程图启用Spring Boot Actuator监控线程池配置日志级别跟踪SQL语句# application.yml配置示例 logging: level: org.flowable: DEBUG org.springframework.jdbc.core: TRACE7.2 单元测试要点使用Flowable的Test注解自动清理数据模拟并行审批场景测试边界条件如超长审批意见FlowableTest public class LeaveApprovalTest { Test public void testParallelApproval() { // 启动流程 ProcessInstance instance runtimeService.startProcessInstanceByKey(parallel_leave); // 验证并行任务数 long taskCount taskService.createTaskQuery() .processInstanceId(instance.getId()) .count(); assertEquals(2, taskCount); } }在实际项目中理解数据流转关系对排查复杂问题至关重要。建议开发者搭建测试环境通过修改单个参数观察数据库变化这种实操训练比文档学习更有效。

相关文章:

芋道视频199 - 工作流 - 数据流转图 - ruoyi-vue-pro

1. 工作流引擎与Ruoyi-Vue-Pro的深度整合 在Ruoyi-Vue-Pro项目中,工作流引擎扮演着业务流程自动化的核心角色。以请假流程为例,从员工提交申请到领导审批再到HR备案,整个流程涉及多角色协作和状态流转。Flowable作为底层引擎,通过…...

ATF-54143 LNA设计复盘:我是如何权衡噪声、增益与稳定性的(附完整ADS工程)

ATF-54143 LNA设计复盘:噪声、增益与稳定性的深度权衡 在2.4GHz频段的低噪声放大器(LNA)设计中,工程师往往面临噪声系数、增益和稳定性之间的复杂权衡。本文将基于ATF-54143晶体管,分享我在实际项目中如何通过系统化的设计流程解决这些核心矛…...

ESP32 LVGL 8.1样式背景避坑指南:bg_grad_stop设置不对,你的渐变为啥不显示?

ESP32 LVGL 8.1样式背景开发实战:从渐变失效到高级视觉效果的深度解析 在嵌入式GUI开发中,LVGL因其轻量级和丰富的功能而广受欢迎。但当我们尝试在ESP32上实现复杂的样式背景效果时,往往会遇到各种"诡异"现象——特别是渐变效果不显…...

从X86到鲲鹏:除了代码迁移,DevKit的性能分析和调优助手怎么用?

从X86到鲲鹏:DevKit性能调优实战指南 当应用从X86平台迁移到鲲鹏架构后,许多开发者会发现性能表现与预期存在差距。这种差异往往源于架构特性未被充分挖掘,或存在隐藏的内存问题。本文将深入解析如何利用鲲鹏DevKit中的四大核心工具——系统性…...

数字IC面试必问:CMOS反相器尺寸链优化与延时最小化实战解析

数字IC面试必问:CMOS反相器尺寸链优化与延时最小化实战解析 在数字集成电路设计的面试中,CMOS反相器尺寸链优化几乎是必考题。这道题看似简单,却涵盖了器件物理、电路设计和工程权衡的深层逻辑。本文将用工程师的实战视角,拆解反…...

LX Music桌面版终极指南:开源免费的多平台音乐聚合播放器

LX Music桌面版终极指南:开源免费的多平台音乐聚合播放器 【免费下载链接】lx-music-desktop 一个基于 Electron 的音乐软件 项目地址: https://gitcode.com/GitHub_Trending/lx/lx-music-desktop 还在为不同音乐平台间的切换烦恼吗?想在一个软件…...

用PyTorch复现LeNet:从MNIST手写数字识别到理解卷积神经网络(保姆级代码解析)

用PyTorch实战LeNet:从零构建经典CNN模型并理解其设计哲学 在深度学习的世界里,LeNet就像是一本启蒙读物——它简单到足以让初学者理解,却又深刻到能揭示卷积神经网络(CNN)的核心思想。1998年由Yann LeCun提出的这个架构,不仅成功…...

OpenBoardView:完全免费的.brd电路板文件查看终极指南

OpenBoardView:完全免费的.brd电路板文件查看终极指南 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView 还在为昂贵的电路板设计软件而烦恼吗?想要一款真正免费、跨平台、功能强大的.…...

免费开源AMD Ryzen处理器终极调试指南:SMUDebugTool完整教程

免费开源AMD Ryzen处理器终极调试指南:SMUDebugTool完整教程 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: http…...

CSS如何控制placeholder文字的颜色_使用--placeholder伪元素

Chrome/Firefox中::placeholder颜色不生效,主因是CSS优先级覆盖、浏览器兼容性差异或框架样式重置;需用双冒号语法、兼顾各浏览器前缀、避免内联样式干扰,并通过class而非style动态控制。Chrome/Firefox里::placeholder颜色不生效&#xff1f…...

别再傻傻分不清!EPLAN里连接定义点和电位定义点的核心区别与实战用法

EPLAN电气设计实战:连接定义点与电位定义点的深度解析与应用指南 在EPLAN电气设计软件中,连接定义点(Connection Definition Point)和电位定义点(Potential Definition Point)是两种看似相似却功能迥异的核心元素。许多工程师在使用过程中容易混淆两者&a…...

免费CAD软件LitCAD:3分钟上手的轻量级绘图解决方案终极指南

免费CAD软件LitCAD:3分钟上手的轻量级绘图解决方案终极指南 【免费下载链接】LitCAD A very simple CAD developed by C#. 项目地址: https://gitcode.com/gh_mirrors/li/LitCAD 还在为高昂的CAD软件费用而烦恼吗?或者被复杂的设计工具搞得晕头转…...

别再死记硬背了!用C语言递归搞定二叉树遍历转换(PTA真题7-1保姆级解析)

从手算到代码:二叉树遍历转换的思维跃迁 当你在PTA或LeetCode上遇到"已知后序和中序遍历求先序遍历"这类题目时,是否也曾陷入"先建树再遍历"的思维定式?实际上,这类问题的核心在于发现遍历序列间的隐藏规律&a…...

如何在macOS上高效使用HSTracker:炉石传说智能助手与卡组管理实战指南

如何在macOS上高效使用HSTracker:炉石传说智能助手与卡组管理实战指南 【免费下载链接】HSTracker A deck tracker and deck manager for Hearthstone on macOS 项目地址: https://gitcode.com/gh_mirrors/hs/HSTracker HSTracker是macOS平台上一款专业的炉石…...

告别三极管!用CH340X/C直连搞定CH32/STM32一键下载(附完整电路图与驱动版本避坑)

极简主义嵌入式开发:CH340直连实现CH32/STM32一键下载全攻略 当你在深夜调试一个嵌入式项目,反复插拔USB线、手动切换BOOT跳线、按复位按钮时,是否想过——这些繁琐操作真的有必要吗?传统的一键下载电路通常需要两个三极管构成的逻…...

Docker部署避坑:OpenClaw容器内无法使用代理?网络模式选择建议

“在本地跑得好好的OpenClaw,一放到Docker容器里,代理就不生效了……”“明明docker-compose.yml里配了环境变量,容器里curl也能通,但OpenClaw就是不走代理……”“更离谱的是,容器能ping通外网,但OpenClaw…...

如何免费快速将网页小说转换为EPUB电子书:WebToEpub完整教程

如何免费快速将网页小说转换为EPUB电子书:WebToEpub完整教程 【免费下载链接】WebToEpub A simple Chrome (and Firefox) Extension that converts Web Novels (and other web pages) into an EPUB. 项目地址: https://gitcode.com/gh_mirrors/we/WebToEpub …...

从module变量到intent参数:手把手教你写出更安全、更地道的Fortran子程序

从module变量到intent参数:手把手教你写出更安全、更地道的Fortran子程序 Fortran作为科学计算领域的常青树,其独特的模块化设计和参数传递机制常常让从C/Python转来的开发者感到困惑。本文将带你深入理解module变量的作用域陷阱、参数传递的底层逻辑&am…...

小程序富文本组件mp-html:打破微信原生限制的终极解决方案

小程序富文本组件mp-html:打破微信原生限制的终极解决方案 【免费下载链接】mp-html 小程序富文本组件,支持渲染和编辑 html,支持在微信、QQ、百度、支付宝、头条和 uni-app 平台使用 项目地址: https://gitcode.com/gh_mirrors/mp/mp-html…...

如何在3分钟内为视频添加专业字幕:开源工具终极指南

如何在3分钟内为视频添加专业字幕:开源工具终极指南 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 想象一下,…...

IPXWrapper终极指南:5分钟让经典游戏在现代电脑上联机重生

IPXWrapper终极指南:5分钟让经典游戏在现代电脑上联机重生 【免费下载链接】ipxwrapper 项目地址: https://gitcode.com/gh_mirrors/ip/ipxwrapper 你是否怀念那些经典老游戏的局域网对战乐趣?《红色警戒2》、《暗黑破坏神》、《星际争霸》这些承…...

终极指南:如何用Office Custom UI Editor打造专属办公界面

终极指南:如何用Office Custom UI Editor打造专属办公界面 【免费下载链接】office-custom-ui-editor Standalone tool to edit custom UI part of Office open document file format 项目地址: https://gitcode.com/gh_mirrors/of/office-custom-ui-editor …...

考研数学二极限计算:避开等价无穷小使用陷阱的3个实战技巧

考研数学二极限计算:避开等价无穷小使用陷阱的3个实战技巧 极限计算是考研数学二的核心考点,也是考生最容易失分的模块之一。其中,等价无穷小的使用更是"重灾区"——看似简单的替换规则,在实际解题中却暗藏诸多陷阱。本…...

3大技术方案构建无国界AO3镜像:开源社区如何守护全球创作自由

3大技术方案构建无国界AO3镜像:开源社区如何守护全球创作自由 【免费下载链接】AO3-Mirror-Site 项目地址: https://gitcode.com/gh_mirrors/ao/AO3-Mirror-Site 在数字时代,当创作自由遭遇地域限制,技术的力量成为连接全球创作者与读…...

你的数字青春正在消失?GetQzonehistory帮你永久保存QQ空间珍贵记忆

你的数字青春正在消失?GetQzonehistory帮你永久保存QQ空间珍贵记忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 在数字时代,QQ空间承载了无数人的青春记忆&am…...

别再写丑UI了!用Qt Quick的TabViewStyle,5分钟打造高颜值选项卡

用Qt Quick的TabViewStyle打造高颜值选项卡:从设计到实现的完整指南 在移动应用和桌面软件中,选项卡(TabView)是最常见的导航组件之一。一个设计精良的选项卡系统不仅能提升用户体验,还能为应用增添专业感。Qt Quick的TabViewStyle提供了强大…...

揭秘低查重AI教材编写秘籍,AI写教材工具助你高效完成专业教材!

在教材编写过程中,如何平衡原创性与合规性是一个新的挑战。许多创作者往往在借鉴优秀教材的内容时,难免担心查重率超出标准;而在尝试独立撰写知识点时,又会顾虑逻辑是否严谨、信息是否准确。更重要的是,当引用他人的研…...

Mac Mouse Fix终极指南:5分钟解锁鼠标隐藏功能,让普通鼠标在macOS上超越触控板

Mac Mouse Fix终极指南:5分钟解锁鼠标隐藏功能,让普通鼠标在macOS上超越触控板 【免费下载链接】mac-mouse-fix Mac Mouse Fix - Make Your $10 Mouse Better Than an Apple Trackpad! 项目地址: https://gitcode.com/GitHub_Trending/ma/mac-mouse-fi…...

解锁B站4K高清下载:Python工具完全指南与实战教程

解锁B站4K高清下载:Python工具完全指南与实战教程 【免费下载链接】bilibili-downloader B站视频下载,支持下载大会员清晰度4K,持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 你是否曾经因为网络波动…...

用STM32F103RCT6驱动4寸ST7796S屏,从接线到显示图片的保姆级教程

STM32F103RCT6驱动4寸ST7796S液晶屏全流程实战指南 第一次拿到STM32开发板和4寸液晶屏时,看着密密麻麻的引脚和陌生的专业术语,确实容易让人望而生畏。但别担心,本文将手把手带你完成从硬件连接到软件调试的全过程。不同于简单的代码复制粘贴…...