提供一个工作流的表设计

限制:允许定义多个工作流,但每个条工作流的两个节点间仅允许【同意】、【拒绝】两种选择。无法支持动态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='业务数据-实际工作流表';
相关推荐
_日拱一卒37 分钟前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠44 分钟前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨1 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
源码宝2 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区2 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
金銀銅鐵2 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
云烟成雨TD2 小时前
Spring AI Alibaba 1.x 系列【63】AI Agent 长期记忆
java·人工智能·spring
憧憬成为java架构高手的小白2 小时前
苍穹外卖--day09
java·spring boot·百度
学代码的真由酱3 小时前
Java多用户一对一网页聊天室-测试报告
java·开发语言·功能测试·测试
Jasonakeke3 小时前
SpringBoot自动配置原理揭秘
java·spring boot·后端