approval_workflow.sql 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. -- 审批流程框架数据库表结构
  2. -- 创建时间:2025-09-06
  3. -- 1. 审批流程定义表
  4. DROP TABLE IF EXISTS `approval_workflow_definition`;
  5. CREATE TABLE `approval_workflow_definition` (
  6. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  7. `workflow_code` varchar(50) NOT NULL COMMENT '流程代码',
  8. `workflow_name` varchar(100) NOT NULL COMMENT '流程名称',
  9. `workflow_type` varchar(50) NOT NULL COMMENT '流程类型(PERSONAL:个人级别,SECTION:科级,GROUP:班组级,SEIZURE_REPORT:查获上报)',
  10. `description` varchar(500) DEFAULT NULL COMMENT '流程描述',
  11. `status` char(1) DEFAULT '0' COMMENT '状态(0正常 1停用)',
  12. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  13. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  14. `update_by` varchar(64) DEFAULT '' COMMENT '更新者',
  15. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  16. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  17. PRIMARY KEY (`id`),
  18. UNIQUE KEY `uk_workflow_code` (`workflow_code`)
  19. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批流程定义表';
  20. -- 2. 审批节点定义表
  21. DROP TABLE IF EXISTS `approval_node_definition`;
  22. CREATE TABLE `approval_node_definition` (
  23. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  24. `workflow_id` bigint(20) NOT NULL COMMENT '流程定义ID',
  25. `node_code` varchar(50) NOT NULL COMMENT '节点代码',
  26. `node_name` varchar(100) NOT NULL COMMENT '节点名称',
  27. `node_type` varchar(50) NOT NULL COMMENT '节点类型(START:开始,APPROVE:审批,NOTIFY:通知,END:结束)',
  28. `sort_order` int(11) NOT NULL COMMENT '节点顺序',
  29. `approver_type` varchar(50) DEFAULT NULL COMMENT '审批人类型(USER:指定用户,ROLE:角色,DEPT:部门,GROUP_LEADER:班组长,SECTION_LEADER:科长)',
  30. `approver_value` varchar(200) DEFAULT NULL COMMENT '审批人值',
  31. `can_reject` char(1) DEFAULT '0' COMMENT '是否可驳回(0否 1是)',
  32. `is_required` char(1) DEFAULT '1' COMMENT '是否必须审批(0否 1是)',
  33. `timeout_hours` int(11) DEFAULT NULL COMMENT '超时小时数',
  34. `status` char(1) DEFAULT '0' COMMENT '状态(0正常 1停用)',
  35. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  36. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  37. `update_by` varchar(64) DEFAULT '' COMMENT '更新者',
  38. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  39. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  40. PRIMARY KEY (`id`),
  41. KEY `idx_workflow_id` (`workflow_id`),
  42. UNIQUE KEY `uk_workflow_node` (`workflow_id`, `node_code`)
  43. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批节点定义表';
  44. -- 3. 审批实例表
  45. DROP TABLE IF EXISTS `approval_instance`;
  46. CREATE TABLE `approval_instance` (
  47. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  48. `instance_no` varchar(50) NOT NULL COMMENT '实例编号',
  49. `workflow_id` bigint(20) NOT NULL COMMENT '流程定义ID',
  50. `title` varchar(200) NOT NULL COMMENT '审批标题',
  51. `business_type` varchar(50) NOT NULL COMMENT '业务类型',
  52. `business_id` bigint(20) NOT NULL COMMENT '业务ID',
  53. `business_data` text COMMENT '业务数据(JSON格式)',
  54. `submitter_id` bigint(20) NOT NULL COMMENT '提交人ID',
  55. `submitter_name` varchar(50) NOT NULL COMMENT '提交人姓名',
  56. `submit_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '提交时间',
  57. `current_node_id` bigint(20) DEFAULT NULL COMMENT '当前节点ID',
  58. `status` varchar(20) DEFAULT 'RUNNING' COMMENT '实例状态(RUNNING:运行中,COMPLETED:已完成,REJECTED:已驳回,CANCELLED:已取消)',
  59. `completion_time` datetime DEFAULT NULL COMMENT '完成时间',
  60. `urgent_level` varchar(20) DEFAULT 'NORMAL' COMMENT '紧急程度(LOW:低,NORMAL:普通,HIGH:高,URGENT:紧急)',
  61. `form_data` json DEFAULT NULL COMMENT '表单数据',
  62. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  63. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  64. `update_by` varchar(64) DEFAULT '' COMMENT '更新者',
  65. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  66. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  67. PRIMARY KEY (`id`),
  68. UNIQUE KEY `uk_instance_no` (`instance_no`),
  69. KEY `idx_workflow_id` (`workflow_id`),
  70. KEY `idx_submitter_id` (`submitter_id`),
  71. KEY `idx_business` (`business_type`, `business_id`),
  72. KEY `idx_status` (`status`)
  73. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批实例表';
  74. -- 4. 审批任务表
  75. DROP TABLE IF EXISTS `approval_task`;
  76. CREATE TABLE `approval_task` (
  77. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  78. `task_no` varchar(50) NOT NULL COMMENT '任务编号',
  79. `instance_id` bigint(20) NOT NULL COMMENT '实例ID',
  80. `node_id` bigint(20) NOT NULL COMMENT '节点ID',
  81. `task_name` varchar(100) NOT NULL COMMENT '任务名称',
  82. `assignee_id` bigint(20) NOT NULL COMMENT '处理人ID',
  83. `assignee_name` varchar(50) NOT NULL COMMENT '处理人姓名',
  84. `assign_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '分配时间',
  85. `status` varchar(20) DEFAULT 'PENDING' COMMENT '任务状态(PENDING:待处理,APPROVED:已同意,REJECTED:已驳回,CANCELLED:已取消)',
  86. `complete_time` datetime DEFAULT NULL COMMENT '完成时间',
  87. `comment` text COMMENT '审批意见',
  88. `form_data` json DEFAULT NULL COMMENT '表单数据',
  89. `timeout_time` datetime DEFAULT NULL COMMENT '超时时间',
  90. `is_timeout` char(1) DEFAULT '0' COMMENT '是否超时(0否 1是)',
  91. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  92. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  93. `update_by` varchar(64) DEFAULT '' COMMENT '更新者',
  94. `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  95. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  96. PRIMARY KEY (`id`),
  97. UNIQUE KEY `uk_task_no` (`task_no`),
  98. KEY `idx_instance_id` (`instance_id`),
  99. KEY `idx_node_id` (`node_id`),
  100. KEY `idx_assignee_id` (`assignee_id`),
  101. KEY `idx_status` (`status`)
  102. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批任务表';
  103. -- 5. 审批历史表
  104. DROP TABLE IF EXISTS `approval_history`;
  105. CREATE TABLE `approval_history` (
  106. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  107. `instance_id` bigint(20) NOT NULL COMMENT '实例ID',
  108. `task_id` bigint(20) DEFAULT NULL COMMENT '任务ID',
  109. `node_id` bigint(20) DEFAULT NULL COMMENT '节点ID',
  110. `node_name` varchar(100) DEFAULT NULL COMMENT '节点名称',
  111. `action` varchar(50) NOT NULL COMMENT '操作(SUBMIT:提交,APPROVE:同意,REJECT:驳回,CANCEL:取消,COMPLETE:完成)',
  112. `operator_id` bigint(20) NOT NULL COMMENT '操作人ID',
  113. `operator_name` varchar(50) NOT NULL COMMENT '操作人姓名',
  114. `operation_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '操作时间',
  115. `comment` text COMMENT '操作意见',
  116. `form_data` json DEFAULT NULL COMMENT '表单数据',
  117. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  118. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  119. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  120. PRIMARY KEY (`id`),
  121. KEY `idx_instance_id` (`instance_id`),
  122. KEY `idx_task_id` (`task_id`),
  123. KEY `idx_operator_id` (`operator_id`),
  124. KEY `idx_operation_time` (`operation_time`)
  125. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批历史表';
  126. -- 6. 审批抄送表
  127. DROP TABLE IF EXISTS `approval_cc`;
  128. CREATE TABLE `approval_cc` (
  129. `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  130. `instance_id` bigint(20) NOT NULL COMMENT '实例ID',
  131. `cc_user_id` bigint(20) NOT NULL COMMENT '抄送用户ID',
  132. `cc_user_name` varchar(50) NOT NULL COMMENT '抄送用户姓名',
  133. `cc_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '抄送时间',
  134. `is_read` char(1) DEFAULT '0' COMMENT '是否已读(0否 1是)',
  135. `read_time` datetime DEFAULT NULL COMMENT '阅读时间',
  136. `create_by` varchar(64) DEFAULT '' COMMENT '创建者',
  137. `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  138. `remark` varchar(500) DEFAULT NULL COMMENT '备注',
  139. PRIMARY KEY (`id`),
  140. KEY `idx_instance_id` (`instance_id`),
  141. KEY `idx_cc_user_id` (`cc_user_id`)
  142. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='审批抄送表';
  143. -- 初始化审批流程定义数据
  144. INSERT INTO `approval_workflow_definition` VALUES
  145. (1, 'PERSONAL_LEVEL', '个人级别审批流程', 'PERSONAL', '被检查级别为个人,无需审批,发送待办通知', '0', 'admin', NOW(), 'admin', NOW(), '个人级别检查流程'),
  146. (2, 'SECTION_LEVEL', '科级审批流程', 'SECTION', '被检查级别为科级,需经科长节点审批', '0', 'admin', NOW(), 'admin', NOW(), '科级检查流程'),
  147. (3, 'GROUP_LEVEL', '班组级审批流程', 'GROUP', '被检查级别为班组级,需班组长处理', '0', 'admin', NOW(), 'admin', NOW(), '班组级检查流程'),
  148. (4, 'SEIZURE_REPORT_STAFF', '查获上报流程(安检员)', 'SEIZURE_REPORT', '安检员提交的查获上报流程', '0', 'admin', NOW(), 'admin', NOW(), '安检员查获上报流程'),
  149. (5, 'SEIZURE_REPORT_LEADER', '查获上报流程(班组长)', 'SEIZURE_REPORT', '班组长提交的查获上报流程', '0', 'admin', NOW(), 'admin', NOW(), '班组长查获上报流程');
  150. -- 初始化审批节点定义数据
  151. -- 个人级别流程节点
  152. INSERT INTO `approval_node_definition` VALUES
  153. (1, 1, 'START', '开始', 'START', 1, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程开始'),
  154. (2, 1, 'NOTIFY', '通知确认', 'NOTIFY', 2, 'USER', NULL, '0', '1', 24, '0', 'admin', NOW(), 'admin', NOW(), '发送待办通知给组员'),
  155. (3, 1, 'END', '归档', 'END', 3, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程结束归档');
  156. -- 科级流程节点
  157. INSERT INTO `approval_node_definition` VALUES
  158. (4, 2, 'START', '开始', 'START', 1, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程开始'),
  159. (5, 2, 'SECTION_LEADER', '科长审批', 'APPROVE', 2, 'SECTION_LEADER', NULL, '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '科长选择整改班组'),
  160. (6, 2, 'GROUP_LEADER_RECTIFY', '班组长整改', 'APPROVE', 3, 'GROUP_LEADER', NULL, '1', '1', 72, '0', 'admin', NOW(), 'admin', NOW(), '班组长填写整改详情'),
  161. (7, 2, 'SECTION_REVIEW', '科长复审', 'APPROVE', 4, 'SECTION_LEADER', NULL, '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '科长审批整改结果'),
  162. (8, 2, 'QUALITY_REVIEW', '质检科审批', 'APPROVE', 5, 'DEPT_SECTION_LEADER', 'quality_inspector', '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '质检科最终审批'),
  163. (9, 2, 'END', '归档', 'END', 6, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程结束归档');
  164. -- 班组级流程节点
  165. INSERT INTO `approval_node_definition` VALUES
  166. (10, 3, 'START', '开始', 'START', 1, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程开始'),
  167. (11, 3, 'SECTION_LEADER', '科长审批', 'APPROVE', 2, 'SECTION_LEADER', NULL, '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '科长审批选择班组'),
  168. (12, 3, 'GROUP_LEADER_RECTIFY', '班组长整改', 'APPROVE', 3, 'GROUP_LEADER', NULL, '1', '1', 72, '0', 'admin', NOW(), 'admin', NOW(), '班组长填写整改详情'),
  169. (13, 3, 'SECTION_REVIEW', '科长复审', 'APPROVE', 4, 'SECTION_LEADER', NULL, '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '科长最终审批'),
  170. (14, 3, 'END', '归档', 'END', 5, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程结束归档');
  171. -- 查获上报流程(安检员)节点
  172. INSERT INTO `approval_node_definition` VALUES
  173. (15, 4, 'START', '开始', 'START', 1, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '安检员提交'),
  174. (16, 4, 'GROUP_LEADER', '班组长审批', 'APPROVE', 2, 'GROUP_LEADER', NULL, '1', '1', 24, '0', 'admin', NOW(), 'admin', NOW(), '班组长审批'),
  175. (17, 4, 'END', '归档', 'END', 3, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程结束归档');
  176. -- 查获上报流程(班组长)节点
  177. INSERT INTO `approval_node_definition` VALUES
  178. (18, 5, 'START', '开始', 'START', 1, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '班组长提交'),
  179. (19, 5, 'SECTION_LEADER', '科长审批', 'APPROVE', 2, 'SECTION_LEADER', NULL, '1', '1', 48, '0', 'admin', NOW(), 'admin', NOW(), '科长审批'),
  180. (20, 5, 'END', '归档', 'END', 3, NULL, NULL, '0', '1', NULL, '0', 'admin', NOW(), 'admin', NOW(), '流程结束归档');