通用工作流引擎数据库设计的简单构思

2024-05-07 09:18

本文主要是介绍通用工作流引擎数据库设计的简单构思,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通用工作流引擎数据库设计的简单构思



什么是工作流和工作流引擎

百度百科:

工作流(Workflow),指“业务过程的部分或整体在计算机应用环境下的自动化”。是对工作流程及其各操作步骤之间业务规则的抽象、概括描述。在计算机中,工作流属于计算机支持的协同工作(CSCW)的一部分。后者是普遍地研究一个群体如何在计算机的帮助下实现协同工作的。
工作流主要解决的主要问题是:为了实现某个业务目标,利用计算机在多个参与者之间按某种预定规则自动传递文档、信息或者任务。

维基百科:

A workflow consists of an orchestrated and repeatable pattern of business activity enabled by the systematic organization of resources into processes that transform materials, provide services, or process information. It can be depicted as a sequence of operations, declared as work of a person or group, an organization of staff, or one or more simple or complex mechanisms.
From a more abstract or higher-level perspective, workflow may be considered a view or representation of real work. The flow being described may refer to a document, service or product that is being transferred from one step to another.
Workflows may be viewed as one fundamental building block to be combined with other parts of an organization’s structure such as information technology, teams, projects and hierarchies.

简单通俗不严谨的讲,工作流就是用于传递信息的一整套流程。

例如,去银行办理贷款,从用户申请到银行审核再到最后用户拿到钱,这整个过程就是一个工作流,银行肯定也有自己的一套工作流系统,用于不同工作人员不同部门之前的写作,从而完成贷款这件事情。

而工作流的核心就是工作流引擎。

所谓工作流引擎是指workflow作为应用系统的一部分,并为之提供对各应用系统有决定作用的根据角色、分工和条件的不同决定信息传递路由、内容等级等核心解决方案。工作流引擎包括了,流程的节点管理、流向管理、流程样例管理等重要功能。


数据库设计

对于一个通用的工作流引擎数据库,我觉得它应该具备以下几个功能:

  1. 工作流引擎适用于多种类型事务
  2. 流程调度流转,如创建,结束,跳跃,回退,终止
  3. 自定义动作及事件发布
  4. 顺序处理与并行处理

这里需要解释一下什么是任务的顺序执行和并行执行
这里写图片描述
(图片来自网络)
上一个任务的处理者指定下一个任务的处理者,必须当前处理人处理完毕,流程才能继续,为顺序处理,上图左边模式。
上一个任务的处理者指定多个处理人,由任一处理人处理,不分前后顺序,当所有处理人处理完毕,即可进入下一步骤,为并行处理,上图右边模式。

最后,我设计出下面的数据库引擎结构
这里写图片描述

  • work表,即通用的工作流程表,代表一项目完整事务,state表示状态,有进行中,完结,终止三种状态,type指向具体事项类型,例如贷款事务,取款事务。
  • task表,即操作任务表,表代表一种操作类型,type指向具体的操作类型,以银行贷款为例,type指向各种具体的审核操作。
  • work_task表,作为中间表,连接work表和task表,state字段表示状态,有进行中,完结,终止三种状态,next_id指向下一个操作,通过操作这个字段,实现流程的回退,跳跃和终止。
  • person表,表示执行task操作的人。
  • task_person表,作为中间表,关联task表和person表,type表示任务操作者的执行类型,有顺序执行和并行执行两种。

设计思路

下面,我将阐述我的设计思路。
我们以银行贷款为例,大致流程为:
用户发起贷款》》审核流程1》》审核流程2》》发放贷款

我们需要根据具体业务加入具体的类型表,最后的数据库结构为

这里写图片描述

其中
这里写图片描述
loan表为贷款业务表,它表示一次贷款,是work的一种类型。

这里写图片描述

通过task的type字段,定义多种实际操作类型,approval1,approval2,draw分别表示单人审核操作,多人审核操作以及用户最后的取款操作。

这里写图片描述

通过work_task表将work和task关联的同时,也实现了task的执行顺序,同时,加入next_id用来表明下一个task,这样我们通过操作next_id就可以动态操作流程。当next_id指向自己的时候,说明流程已经结束。person_state表示执行人的状态。

  • 跳跃:将next_id指向我们最终的task,那么中间的task将会跳过。
  • 回退:为了避免task流程陷入死循环,回退是加入新task,然后再将next_id指向新加入的第一条task。
    例如,原本的流程是abcde,这时我们到了d这一步,需要回退到b,我们就可以在work_task中再加入bc,变成abcdbcde,只要把旧bc的信息复制到新bc上即可。
  • 终止:直接在next_id赋值为空。

这篇关于通用工作流引擎数据库设计的简单构思的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/966941

相关文章

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态