feat(ops): update cleaner status and assignment logic

This commit is contained in:
lzh
2026-01-19 14:56:31 +08:00
parent 73bc3b299f
commit b71558ae07
169 changed files with 57972 additions and 162 deletions

View File

@@ -0,0 +1,32 @@
-- 1. Create ops_area_device_relation table
CREATE TABLE `ops_area_device_relation` (
`id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键',
`area_id` BIGINT NOT NULL COMMENT '运营区域ID',
`device_id` BIGINT NOT NULL COMMENT 'IoT设备ID',
`device_key` VARCHAR(100) NOT NULL COMMENT '设备Key(冗余)',
`product_id` BIGINT NOT NULL COMMENT '产品ID',
`product_key` VARCHAR(100) NOT NULL COMMENT '产品Key(冗余)',
`relation_type` VARCHAR(50) NOT NULL COMMENT '关联类型:TRAFFIC_COUNTER/BEACON/BADGE',
`config_data` TEXT COMMENT '配置数据(JSON格式)',
`enabled` TINYINT(1) NOT NULL DEFAULT 1 COMMENT '是否启用',
`creator` VARCHAR(64) DEFAULT '' COMMENT '创建者',
`create_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` VARCHAR(64) DEFAULT '' COMMENT '更新者',
`update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` BIT(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` BIGINT NOT NULL DEFAULT 0 COMMENT '租户ID',
PRIMARY KEY (`id`),
UNIQUE KEY `uk_device` (`device_id`, `deleted`),
KEY `idx_area_id` (`area_id`),
KEY `idx_product_key` (`product_key`),
KEY `idx_relation_type` (`relation_type`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='运营区域设备关联表';
-- 2. Alter ops_order table to add trigger fields
ALTER TABLE `ops_order`
ADD COLUMN `trigger_source` VARCHAR(50) DEFAULT 'MANUAL' COMMENT '触发来源MANUAL/IOT_TRAFFIC/IOT_ALERT' AFTER `source_type`,
ADD COLUMN `trigger_rule_id` BIGINT DEFAULT NULL COMMENT '触发规则ID(关联iot_scene_rule.id)' AFTER `trigger_source`,
ADD COLUMN `trigger_device_id` BIGINT DEFAULT NULL COMMENT '触发设备ID' AFTER `trigger_rule_id`,
ADD COLUMN `trigger_device_key` VARCHAR(100) DEFAULT NULL COMMENT '触发设备Key' AFTER `trigger_device_id`,
ADD COLUMN `assignee_device_id` BIGINT DEFAULT NULL COMMENT '负责设备ID(关联iot_device.id)' AFTER `assignee_id`,
ADD COLUMN `assignee_device_key` VARCHAR(100) DEFAULT NULL COMMENT '负责设备Key' AFTER `assignee_device_id`;

234
sql/mysql/ops.sql Normal file
View File

@@ -0,0 +1,234 @@
/*
Navicat Premium Dump SQL
Source Server : 腾讯云-124.221.55.225
Source Server Type : MySQL
Source Server Version : 80044 (8.0.44)
Source Host : 124.221.55.225:3306
Source Schema : aiot-platform
Target Server Type : MySQL
Target Server Version : 80044 (8.0.44)
File Encoding : 65001
Date: 17/01/2026 15:01:11
*/
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for ops_bus_area
-- ----------------------------
DROP TABLE IF EXISTS `ops_bus_area`;
CREATE TABLE `ops_bus_area` (
`id` bigint UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '区域ID主键',
`parent_id` bigint UNSIGNED NULL DEFAULT NULL COMMENT '父级区域ID用于构建区域树',
`parent_path` varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '父级路径1/2/3便于查询所有子区域',
`area_name` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '区域名称',
`area_code` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '区域业务编码(可选,全局唯一)',
`area_type` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '区域层级类型PARK=园区/BUILDING=楼栋/FLOOR=楼层/FUNCTION=功能区域)',
`function_type` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '功能类型MALE_TOILET=男卫/FEMALE_TOILET=女卫/PUBLIC=公共区/ELEVATOR=电梯厅等)',
`floor_no` int NULL DEFAULT NULL COMMENT '楼层号2、-1',
`cleaning_frequency` int NULL DEFAULT 1 COMMENT '保洁频率(次/天)',
`standard_duration` int NULL DEFAULT NULL COMMENT '标准保洁时长(分钟)',
`area_level` varchar(16) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '区域等级HIGH=高优先级/MEDIUM=中/LOW=低)',
`is_active` bit(1) NOT NULL DEFAULT b'1' COMMENT '是否启用',
`sort` int NOT NULL DEFAULT 0 COMMENT '显示排序',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `uk_area_code`(`area_code` ASC, `deleted` ASC) USING BTREE,
INDEX `idx_parent_id`(`parent_id` ASC) USING BTREE,
INDEX `idx_area_type`(`area_type` ASC) USING BTREE,
INDEX `idx_floor_no`(`floor_no` ASC) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '业务区域' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order
-- ----------------------------
DROP TABLE IF EXISTS `ops_order`;
CREATE TABLE `ops_order` (
`id` bigint NOT NULL COMMENT '工单ID',
`order_code` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '工单编号WO202501040001',
`order_type` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '工单类型CLEAN=保洁/REPAIR=维修/SECURITY=安保/SERVICE=客服)',
`source_type` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '来源TRAFFIC=流量触发/INSPECTION=巡检发现/MANUAL=手动创建/SCHEDULE=定时排班)',
`title` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '工单标题',
`description` text CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL COMMENT '工单描述/详情',
`priority` tinyint NOT NULL DEFAULT 2 COMMENT '优先级0=P0紧急 1=P1重要 2=P2普通',
`status` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT 'PENDING' COMMENT '工单状态PENDING待分配/ASSIGNED已分配/ARRIVED已到岗/PAUSED已暂停/COMPLETED已完成/CANCELLED已取消',
`area_id` bigint NULL DEFAULT NULL COMMENT '区域ID',
`location` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '具体位置描述(冗余,便于查询)',
`urgent_reason` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '加急原因',
`assignee_id` bigint NULL DEFAULT NULL COMMENT '当前执行人ID',
`inspector_id` bigint NULL DEFAULT NULL COMMENT '巡检员ID发起人',
`start_time` datetime NULL DEFAULT NULL COMMENT '工单开始时间ARRIVED状态时间',
`end_time` datetime NULL DEFAULT NULL COMMENT '工单结束时间COMPLETED状态时间',
`inspector_accept_time` datetime NULL DEFAULT NULL COMMENT '巡检员验收时间',
`quality_score` tinyint NULL DEFAULT NULL COMMENT '验收评分1-5星',
`quality_comment` varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '<EFBFBD><EFBFBD><EFBFBD>收评语',
`response_seconds` int NULL DEFAULT NULL COMMENT '响应耗时(秒,派单到接单)',
`completion_seconds` int NULL DEFAULT NULL COMMENT '完成耗时(秒,接单到完成)',
`flow_instance_id` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT 'Flowable流程实例ID预留',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `uk_order_code`(`order_code` ASC, `deleted` ASC) USING BTREE,
INDEX `idx_order_type`(`order_type` ASC) USING BTREE,
INDEX `idx_status`(`status` ASC) USING BTREE,
INDEX `idx_priority`(`priority` ASC) USING BTREE,
INDEX `idx_assignee`(`assignee_id` ASC) USING BTREE,
INDEX `idx_area`(`area_id` ASC) USING BTREE,
INDEX `idx_create_time`(`create_time` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '通用工单' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order_clean_ext
-- ----------------------------
DROP TABLE IF EXISTS `ops_order_clean_ext`;
CREATE TABLE `ops_order_clean_ext` (
`id` bigint NOT NULL COMMENT '主键',
`ops_order_id` bigint NOT NULL COMMENT '工单ID',
`is_auto` tinyint NULL DEFAULT 1 COMMENT '是否自动工单1=自动 0=手动)',
`expected_duration` int NULL DEFAULT NULL COMMENT '预计作业时长(分钟)',
`arrived_time` datetime NULL DEFAULT NULL COMMENT '实际到岗时间',
`completed_time` datetime NULL DEFAULT NULL COMMENT '实际完成时间',
`pause_start_time` datetime NULL DEFAULT NULL COMMENT '暂停开始时间',
`pause_end_time` datetime NULL DEFAULT NULL COMMENT '暂停结束时间',
`total_pause_seconds` int NULL DEFAULT 0 COMMENT '累计暂停时长(秒)',
`cleaning_type` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '保洁类型ROUTINE=日常/DEEP=深度/SPOT=点状/EMERGENCY=应急)',
`difficulty_level` tinyint NULL DEFAULT NULL COMMENT '难度等级1-5级',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `uk_ops_order_id`(`ops_order_id` ASC, `deleted` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '保洁工单扩展' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order_clean_log
-- ----------------------------
DROP TABLE IF EXISTS `ops_order_clean_log`;
CREATE TABLE `ops_order_clean_log` (
`id` bigint NOT NULL COMMENT '日志ID',
`event_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '事件发生时间',
`event_level` varchar(16) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT 'INFO' COMMENT '日志级别INFO=信息/WARN=警告/ERROR=错误)',
`event_domain` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '领域RULE=规则引擎/DISPATCH=调度/BADGE=工牌/BEACON=信标/SYSTEM=系统)',
`event_type` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '事件类型',
`ops_order_id` bigint NULL DEFAULT NULL COMMENT '关联工单ID',
`area_id` bigint NULL DEFAULT NULL COMMENT '区域ID',
`cleaner_id` bigint NULL DEFAULT NULL COMMENT '保洁员ID',
`device_id` bigint NULL DEFAULT NULL COMMENT '设备ID工牌/信标)',
`event_message` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '可读日志内容',
`event_payload` json NULL COMMENT '结构化上下文',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
INDEX `idx_event_time`(`event_time` ASC) USING BTREE,
INDEX `idx_ops_order_id`(`ops_order_id` ASC) USING BTREE,
INDEX `idx_cleaner_id`(`cleaner_id` ASC) USING BTREE,
INDEX `idx_event_domain_type`(`event_domain` ASC, `event_type` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '保洁业务日志' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order_dispatch
-- ----------------------------
DROP TABLE IF EXISTS `ops_order_dispatch`;
CREATE TABLE `ops_order_dispatch` (
`id` bigint NOT NULL COMMENT '派单ID',
`ops_order_id` bigint NOT NULL COMMENT '工单ID',
`user_id` bigint NOT NULL COMMENT '保洁员用户ID',
`priority` tinyint NULL DEFAULT NULL COMMENT '优先级0=P0紧急 1=P1重要 2=P2普通',
`dispatch_mode` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '派单模式NORMAL=普通/SILENT=静默/URGENT=紧急插队)',
`dispatch_reason` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '派单原因AUTO=自动派单/INSPECT_URGE=巡检催办/MANUAL=手动指派)',
`dispatch_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '派单时间',
`accepted_time` datetime NULL DEFAULT NULL COMMENT '接单时间',
`response_seconds` int NULL DEFAULT NULL COMMENT '响应耗时(秒)',
`device_id` bigint NULL DEFAULT NULL COMMENT '工牌设备ID',
`device_response_time` datetime NULL DEFAULT NULL COMMENT '工牌响应时间(播报/震动)',
`notification_method` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '通知方式VOICE_ONLY=仅语音/VIBRATE_ONLY=仅震动/BOTH=语音+震动)',
`event_message` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '可读日志内容',
`event_payload` json NULL COMMENT '结构化上下文',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
INDEX `idx_ops_order_id`(`ops_order_id` ASC) USING BTREE,
INDEX `idx_user_id`(`user_id` ASC) USING BTREE,
INDEX `idx_dispatch_time`(`dispatch_time` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '工单分派决策' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order_event
-- ----------------------------
DROP TABLE IF EXISTS `ops_order_event`;
CREATE TABLE `ops_order_event` (
`id` bigint NOT NULL COMMENT '事件ID',
`ops_order_id` bigint NOT NULL COMMENT '工单ID',
`from_status` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '原状态',
`to_status` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '新状态',
`event_type` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '事件类型CREATE/ASSIGN/ACCEPT/ARRIVE/PAUSE/RESUME/COMPLETE/CANCEL',
`operator_type` varchar(16) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT 'SYSTEM' COMMENT '操作人类型SYSTEM=系统/CLEANER=保洁员/INSPECTOR=巡检员)',
`operator_id` bigint NULL DEFAULT NULL COMMENT '操作人ID',
`operator_name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '操作人姓名(冗余)',
`event_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '发生时间',
`remark` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '说明',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
INDEX `idx_ops_order_id`(`ops_order_id` ASC) USING BTREE,
INDEX `idx_event_time`(`event_time` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = 'FSM 事件流' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Table structure for ops_order_queue
-- ----------------------------
DROP TABLE IF EXISTS `ops_order_queue`;
CREATE TABLE `ops_order_queue` (
`id` bigint NOT NULL COMMENT '队列ID',
`user_id` bigint NOT NULL COMMENT '保洁员用户ID',
`ops_order_id` bigint NOT NULL COMMENT '工单ID',
`queue_index` int NOT NULL COMMENT '队列顺序1表示最高优先级',
`priority` tinyint NOT NULL DEFAULT 2 COMMENT '优先级0=P0紧急 1=P1重要 2=P2普通',
`queue_status` varchar(16) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT 'WAITING' COMMENT '队列状态WAITING=等待中/EXECUTING=执行中/PAUSED=已暂停/CANCELLED=已取消)',
`enqueue_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '入队时间',
`dequeue_time` datetime NULL DEFAULT NULL COMMENT '出队时间(工单开始执行)',
`paused_duration` int NULL DEFAULT 0 COMMENT '累计暂停时长<EFBFBD><EFBFBD><EFBFBD>',
`device_id` bigint NULL DEFAULT NULL COMMENT '工牌设备ID',
`event_message` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '可读日志内容',
`event_payload` json NULL COMMENT '结构化上下文',
`creator` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updater` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '更新者',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',
`tenant_id` bigint NOT NULL DEFAULT 0 COMMENT '租户编号',
PRIMARY KEY (`id`) USING BTREE,
UNIQUE INDEX `uk_user_order`(`user_id` ASC, `ops_order_id` ASC, `deleted` ASC) USING BTREE,
INDEX `idx_user_priority`(`user_id` ASC, `priority` ASC, `queue_status` ASC) USING BTREE,
INDEX `idx_enqueue_time`(`enqueue_time` ASC) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '工单排队队列' ROW_FORMAT = Dynamic;
SET FOREIGN_KEY_CHECKS = 1;