提供一个工作流的表设计

限制:允许定义多个工作流,但每个条工作流的两个节点间仅允许【同意】、【拒绝】两种选择。无法支持动态N无限分支的情况。

sql 复制代码
CREATE TABLE IF NOT EXISTS `Workflow` (
    `id` INT  NOT NULL AUTO_INCREMENT COMMENT 'ID,自增主键',
    `name` VARCHAR(100) NOT NULL COMMENT '工作流名称',
    PRIMARY KEY (`id`)
)  COMMENT='工作流表_工作流定义(没啥大用,只是定义表)';

CREATE TABLE IF NOT EXISTS `Workflow_schema` (
    `id` INT  NOT NULL AUTO_INCREMENT COMMENT 'ID,自增主键',
    `workflowId` VARCHAR(100) NOT NULL COMMENT 'Workflow 外建',
    `status` TINYINT DEFAULT 1 COMMENT '状态',
    `operation_authority_scope` TINYINT DEFAULT 1 COMMENT '允许执行的权限(多个逗号分隔)',
    `agree_to_id` INT  NOT NULL  COMMENT '同意后的下个流程,Workflow_schema 外建,指向本表',
    `reject_to_id` INT  NOT NULL  COMMENT '拒绝后的下个流程,Workflow_schema 外建,指向本表',
    `index` INT  NOT NULL default 1 COMMENT '排序号',
    PRIMARY KEY (`id`)
)  COMMENT='工作流表_工作流流程字典';


CREATE TABLE IF NOT EXISTS `BussinessData` (
    `id` INT  NOT NULL AUTO_INCREMENT COMMENT 'ID,自增主键',
    `data1` VARCHAR(50) NOT NULL COMMENT 'data1',
    `data2` VARCHAR(100) NOT NULL COMMENT 'data2',
    `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `updated_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
    PRIMARY KEY (`id`)
)  COMMENT='业务数据表';


CREATE TABLE IF NOT EXISTS `BussinessData_Workflow` (
    `id` INT  NOT NULL AUTO_INCREMENT COMMENT 'ID,自增主键',
    `parentId` VARCHAR(50) NOT NULL COMMENT 'BussinessData 外建',
    `workflowId` VARCHAR(50) NOT NULL COMMENT 'Workflow 外建,配合 status,能便找到Workflow_schema信息的唯一记录',
    `status` TINYINT DEFAULT 1 COMMENT '状态(冗余字段)',
    `operation_authority` TINYINT DEFAULT 1 COMMENT '执行的权限(具体执行的权限),即该值必须在Workflow_schema 表 operation_authority_scope的范围内',
    `operation_user` TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '执行人',
    `operation_time` TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '执行时间',
    PRIMARY KEY (`id`)
)  COMMENT='业务数据-实际工作流表';
相关推荐
nanxun88611 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户15630681035113 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师15 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师19 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_019 小时前
mac(m5)平台编译openjdk
java
唐青枫2 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马2 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261352 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261352 天前
Java 打印 Word 文档:从基础打印到高级设置
java
用户3521802454752 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程