| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- -- 1.0.110.sql
- -- S8-OVERVIEW-DEMO-DATA-COVERAGE-SEED-1
- -- 为 S8 overview 演示补 6 条覆盖 seed:让 S2/S3/S5 三张卡 + QDC.QUALITY/DELIVERY/INVENTORY 三桶 + 6 个 period
- -- (today / this_week / this_month / last_24h / last_7d / last_30d) 全部有数据;
- -- 全部挂到现有 in_progress 订单(SO-2026-017/018/019)+ 现有部门(D-QA / D-PROD / D-PURCHASE / D-WAREHOUSE),
- -- **不使用 D-UNASSIGNED**。
- -- 执行入口:AutoVersionUpdate.UseAutoVersionUpdate(),csproj Version=1.0.110 主节点首次启动时触发。
- -- 幂等性:
- -- * 主表 INSERT ... ON DUPLICATE KEY UPDATE 走唯一键 (tenant_id, factory_id, exception_code);
- -- 重复执行只刷新 updated_at/updated_by,不刷新 created_at,不破坏时间窗覆盖。
- -- * timeline INSERT ... SELECT ... WHERE NOT EXISTS (exception_id, action_code='CREATE'),防重 6 条。
- -- 安全边界:不新增 exception_type;不动 watch_rule;不改 ado_s8_order_flow_stage;
- -- 不动现有 16 条 ORDER_FLOW_KPI_OVERTIME_DERIVED;source_rule_code 全部为 S8_OVERVIEW_DEMO_COVERAGE_SEED,
- -- rollback 可一键 UPDATE is_deleted=1 WHERE source_rule_code='S8_OVERVIEW_DEMO_COVERAGE_SEED'。
- -- 2026-05-16
- -- 1) 6 条 seed 主表 upsert
- INSERT INTO ado_s8_exception
- (tenant_id, factory_id, exception_code, title, description,
- scene_code, source_type, status, severity, priority_score, priority_level,
- occurrence_dept_id, responsible_dept_id, sla_deadline, timeout_flag,
- created_at, is_deleted, created_by,
- related_object_code, module_code, exception_type_code, source_payload,
- dedup_key, last_detected_at, source_rule_code, source_object_type, source_object_id,
- consecutive_hit_count, consecutive_miss_count,
- stage_code, order_flow_code, rule_mechanism)
- SELECT
- 1, -- tenant_id(与现有 16 条派生异常对齐)
- 1, -- factory_id
- s.exception_code,
- s.title,
- s.description,
- s.stage_code, -- scene_code = stage_code
- 'AUTO_WATCH',
- 'NEW',
- s.severity,
- 0.00,
- 'P3',
- d.RecID, -- occurrence_dept_id
- d.RecID, -- responsible_dept_id(与 occurrence 同值)
- DATE_ADD(s.created_at, INTERVAL IFNULL(t.sla_minutes, 240) MINUTE),
- 0, -- timeout_flag
- s.created_at,
- 0, -- is_deleted
- 'system:s8_overview_demo_coverage_seed',
- s.related_object_code,
- s.stage_code, -- module_code = stage_code
- s.type_code,
- JSON_OBJECT(
- 'seedPurpose', 'S8_OVERVIEW_DEMO_COVERAGE',
- 'stage', s.stage_code,
- 'typeCode', s.type_code,
- 'orderCode', s.related_object_code,
- 'deptCode', s.dept_code,
- 'periodCoverage', s.period_coverage,
- 'source', 'S8_OVERVIEW_DEMO_COVERAGE_SEED'),
- CONCAT('S8_OVERVIEW_DEMO_COVERAGE:', s.stage_code, ':', s.type_code, ':', s.seq),
- s.created_at,
- 'S8_OVERVIEW_DEMO_COVERAGE_SEED',
- 'SALES_ORDER',
- CAST(o.id AS CHAR),
- 1, -- consecutive_hit_count
- 0, -- consecutive_miss_count
- s.stage_code,
- NULL, -- order_flow_code = NULL(S2/S3/S5 不属于 ORDER_FLOW 5 节点)
- 'DATE'
- FROM (
- SELECT 'EX-DEMO-COV-S2-01' AS exception_code, '01' AS seq,
- 'S2' AS stage_code, 'MFG_QUALITY_ABNORMAL' AS type_code, 'SERIOUS' AS severity,
- 'SO-2026-019' AS related_object_code, 'D-QA' AS dept_code,
- CAST('2026-05-16 08:00:00' AS DATETIME) AS created_at,
- '订单 SO-2026-019 制造协同出现批量质量异常 [演示覆盖]' AS title,
- '用于 S8 overview 演示覆盖:S2 制造协同 + QDC.QUALITY;不代表运行时规则命中。' AS description,
- 'today,last_24h,this_week,this_month,last_7d,last_30d' AS period_coverage
- UNION ALL SELECT 'EX-DEMO-COV-S3-01', '01',
- 'S3', 'SUPPLIER_DELIVERY_DELAY_WARNING', 'FOLLOW',
- 'SO-2026-018', 'D-PURCHASE',
- CAST('2026-05-16 09:30:00' AS DATETIME),
- '订单 SO-2026-018 供应商交付延期预警 [演示覆盖]',
- '用于 S8 overview 演示覆盖:S3 供应协同 + QDC.DELIVERY;不代表运行时规则命中。',
- 'today,last_24h,this_week,this_month,last_7d,last_30d'
- UNION ALL SELECT 'EX-DEMO-COV-S5-01', '01',
- 'S5', 'MATERIAL_STOCK_ABNORMAL', 'FOLLOW',
- 'SO-2026-018', 'D-WAREHOUSE',
- CAST('2026-05-16 06:00:00' AS DATETIME), -- 5/16 凌晨:覆盖 today/last_24h
- '订单 SO-2026-018 物料库存水位异常 [演示覆盖]',
- '用于 S8 overview 演示覆盖:S5 物料仓储 + QDC.INVENTORY;不代表运行时规则命中。',
- 'today,last_24h,this_week,this_month,last_7d,last_30d'
- UNION ALL SELECT 'EX-DEMO-COV-S2-02', '02',
- 'S2', 'EQUIP_FAULT', 'SERIOUS',
- 'SO-2026-019', 'D-PROD',
- CAST('2026-05-12 10:00:00' AS DATETIME), -- 本周二:覆盖 this_week/last_7d/this_month/last_30d
- '订单 SO-2026-019 关键设备停机故障 [演示覆盖]',
- '用于 S8 overview 演示覆盖:S2 设备故障,让 D-PROD 出现 SERIOUS;不代表运行时规则命中。',
- 'this_week,this_month,last_7d,last_30d'
- UNION ALL SELECT 'EX-DEMO-COV-S3-02', '02',
- 'S3', 'SUPPLIER_ETA_ISSUE', 'FOLLOW',
- 'SO-2026-017', 'D-PURCHASE',
- CAST('2026-05-12 11:30:00' AS DATETIME),
- '订单 SO-2026-017 供应商未回复 ETA [演示覆盖]',
- '用于 S8 overview 演示覆盖:S3 供应商 ETA 异常(不在 QDC whitelist,仅点亮 S3 卡)。',
- 'this_week,this_month,last_7d,last_30d'
- UNION ALL SELECT 'EX-DEMO-COV-S5-02', '02',
- 'S5', 'INVENTORY_TURNOVER_ABNORMAL', 'FOLLOW',
- 'SO-2026-018', 'D-WAREHOUSE',
- CAST('2026-05-03 09:00:00' AS DATETIME), -- 本月初:覆盖 this_month/last_30d
- '订单 SO-2026-018 库存周转率异常 [演示覆盖]',
- '用于 S8 overview 演示覆盖:S5 库存周转 + QDC.INVENTORY;不代表运行时规则命中。',
- 'this_month,last_30d'
- ) s
- JOIN DepartmentMaster d
- ON d.Department = s.dept_code AND d.factory_ref_id = 1 AND d.IsActive = 1
- LEFT JOIN ado_s8_exception_type t
- ON t.type_code = s.type_code AND t.tenant_id = 0 AND t.factory_id = 0
- LEFT JOIN ado_s8_order_flow_order o
- ON o.order_code = s.related_object_code AND o.is_deleted = 0
- ON DUPLICATE KEY UPDATE
- updated_at = NOW(),
- updated_by = 'system:s8_overview_demo_coverage_seed';
- -- 2) 写 timeline(CREATE 动作,按 (exception_id, action_code) 去重)
- INSERT INTO ado_s8_exception_timeline
- (exception_id, action_code, action_label, from_status, to_status,
- operator_id, operator_name, action_remark, created_at)
- SELECT
- e.id,
- 'CREATE',
- '演示覆盖派生',
- NULL,
- 'NEW',
- NULL,
- 'system',
- 'S8 overview demo coverage seed',
- e.created_at
- FROM ado_s8_exception e
- WHERE e.source_rule_code = 'S8_OVERVIEW_DEMO_COVERAGE_SEED'
- AND NOT EXISTS (
- SELECT 1 FROM ado_s8_exception_timeline tl
- WHERE tl.exception_id = e.id AND tl.action_code = 'CREATE'
- );
- -- 验证 SQL(注释,仅人工核对):
- -- SELECT COUNT(*) FROM ado_s8_exception WHERE is_deleted=0 AND source_rule_code='S8_OVERVIEW_DEMO_COVERAGE_SEED';
- -- SELECT stage_code, severity, COUNT(*) FROM ado_s8_exception WHERE is_deleted=0
- -- GROUP BY stage_code, severity ORDER BY stage_code, severity;
- -- SELECT COUNT(*) FROM ado_s8_exception_timeline WHERE action_remark='S8 overview demo coverage seed';
|