2026-05-10_s3_first_batch_mdp_dwd_ddl.sql 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. -- S3 first batch MDP/DWD DDL for aidopdev.
  2. -- Scope:
  3. -- - mdp_stg_* source staging tables
  4. -- - mdp_std_* S3 standard tables
  5. -- - dwd_supplier_delivery as S3 extension of the global dwd_po_trans purchase fact
  6. -- - dwd_material_readiness / dwd_material_shortage
  7. --
  8. -- Not included:
  9. -- - dwd_process_outsource_delivery, postponed until the S3/S6 outsource boundary is frozen.
  10. -- - metric_value_day and common MDP metadata tables, which are owned by the global design.
  11. --
  12. -- This script creates structures only. Data backfill is executed separately and can be rerun.
  13. CREATE TABLE IF NOT EXISTS mdp_stg_supplier (
  14. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  15. tenant_id BIGINT NULL,
  16. factory_id BIGINT NULL,
  17. company_id BIGINT NULL,
  18. source_system VARCHAR(50) NOT NULL,
  19. source_table VARCHAR(100) NOT NULL,
  20. source_row_id VARCHAR(200) NULL,
  21. source_biz_key VARCHAR(300) NOT NULL,
  22. sync_batch_id VARCHAR(64) NOT NULL,
  23. sync_time DATETIME NOT NULL,
  24. process_status VARCHAR(20) NOT NULL DEFAULT 'PENDING',
  25. process_message VARCHAR(1000) NULL,
  26. raw_data JSON NULL,
  27. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  28. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  29. KEY idx_batch_status (sync_batch_id, process_status),
  30. UNIQUE KEY uk_source_key (source_system, source_table, source_biz_key),
  31. KEY idx_tenant_time (tenant_id, sync_time)
  32. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3供应商贴源表';
  33. CREATE TABLE IF NOT EXISTS mdp_stg_item LIKE mdp_stg_supplier;
  34. ALTER TABLE mdp_stg_item COMMENT='S3物料贴源表';
  35. CREATE TABLE IF NOT EXISTS mdp_stg_source_list LIKE mdp_stg_supplier;
  36. ALTER TABLE mdp_stg_source_list COMMENT='S3货源清单贴源表';
  37. CREATE TABLE IF NOT EXISTS mdp_stg_supply_demand LIKE mdp_stg_supplier;
  38. ALTER TABLE mdp_stg_supply_demand COMMENT='S3供应需求贴源表';
  39. CREATE TABLE IF NOT EXISTS mdp_stg_purchase_order LIKE mdp_stg_supplier;
  40. ALTER TABLE mdp_stg_purchase_order COMMENT='S3采购订单贴源表';
  41. CREATE TABLE IF NOT EXISTS mdp_stg_delivery LIKE mdp_stg_supplier;
  42. ALTER TABLE mdp_stg_delivery COMMENT='S3交货/送货贴源表';
  43. CREATE TABLE IF NOT EXISTS mdp_stg_receipt LIKE mdp_stg_supplier;
  44. ALTER TABLE mdp_stg_receipt COMMENT='S3收货/退货贴源表';
  45. CREATE TABLE IF NOT EXISTS mdp_stg_work_order_material LIKE mdp_stg_supplier;
  46. ALTER TABLE mdp_stg_work_order_material COMMENT='S3工单物料贴源表';
  47. CREATE TABLE IF NOT EXISTS mdp_std_supplier_item (
  48. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  49. tenant_id BIGINT NOT NULL,
  50. factory_id BIGINT NULL,
  51. company_id BIGINT NULL,
  52. source_system VARCHAR(50) NOT NULL,
  53. item_code VARCHAR(100) NOT NULL,
  54. supplier_code VARCHAR(100) NOT NULL,
  55. supplier_name VARCHAR(200) NULL,
  56. supplier_type VARCHAR(50) NULL,
  57. quota_rate DECIMAL(18,6) NULL,
  58. lead_time DECIMAL(18,6) NULL,
  59. min_qty DECIMAL(18,6) NULL,
  60. packaging_qty DECIMAL(18,6) NULL,
  61. price DECIMAL(18,6) NULL,
  62. currency_type VARCHAR(50) NULL,
  63. effective_date DATETIME NULL,
  64. expire_date DATETIME NULL,
  65. status VARCHAR(50) NULL,
  66. source_biz_key VARCHAR(300) NOT NULL,
  67. sync_batch_id VARCHAR(64) NOT NULL,
  68. sync_time DATETIME NOT NULL,
  69. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  70. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  71. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  72. KEY idx_item_supplier (tenant_id, item_code, supplier_code),
  73. KEY idx_supplier (tenant_id, supplier_code)
  74. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准货源清单';
  75. CREATE TABLE IF NOT EXISTS mdp_std_supply_demand (
  76. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  77. tenant_id BIGINT NOT NULL,
  78. factory_id BIGINT NULL,
  79. company_id BIGINT NULL,
  80. source_system VARCHAR(50) NOT NULL,
  81. demand_no VARCHAR(100) NOT NULL,
  82. demand_line VARCHAR(50) NULL,
  83. demand_type VARCHAR(50) NULL,
  84. item_code VARCHAR(100) NOT NULL,
  85. item_name VARCHAR(200) NULL,
  86. required_qty DECIMAL(18,6) NULL,
  87. required_date DATETIME NULL,
  88. supplier_code VARCHAR(100) NULL,
  89. status VARCHAR(50) NULL,
  90. source_biz_key VARCHAR(300) NOT NULL,
  91. sync_batch_id VARCHAR(64) NOT NULL,
  92. sync_time DATETIME NOT NULL,
  93. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  94. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  95. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  96. KEY idx_item_date (tenant_id, item_code, required_date),
  97. KEY idx_status (tenant_id, status)
  98. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准供应需求';
  99. CREATE TABLE IF NOT EXISTS mdp_std_purchase_order (
  100. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  101. tenant_id BIGINT NOT NULL,
  102. factory_id BIGINT NULL,
  103. company_id BIGINT NULL,
  104. source_system VARCHAR(50) NOT NULL,
  105. po_no VARCHAR(100) NOT NULL,
  106. po_line VARCHAR(50) NOT NULL,
  107. po_type VARCHAR(50) NULL,
  108. supplier_code VARCHAR(100) NULL,
  109. item_code VARCHAR(100) NOT NULL,
  110. item_name VARCHAR(200) NULL,
  111. order_qty DECIMAL(18,6) NULL,
  112. received_qty DECIMAL(18,6) NULL,
  113. returned_qty DECIMAL(18,6) NULL,
  114. due_date DATETIME NULL,
  115. need_date DATETIME NULL,
  116. order_date DATETIME NULL,
  117. status VARCHAR(50) NULL,
  118. buyer VARCHAR(100) NULL,
  119. work_order VARCHAR(100) NULL,
  120. source_biz_key VARCHAR(300) NOT NULL,
  121. sync_batch_id VARCHAR(64) NOT NULL,
  122. sync_time DATETIME NOT NULL,
  123. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  124. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  125. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  126. UNIQUE KEY uk_po_line (tenant_id, po_no, po_line),
  127. KEY idx_supplier_due (tenant_id, supplier_code, due_date),
  128. KEY idx_item_due (tenant_id, item_code, due_date),
  129. KEY idx_work_order (tenant_id, work_order)
  130. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准采购订单';
  131. CREATE TABLE IF NOT EXISTS mdp_std_delivery_schedule (
  132. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  133. tenant_id BIGINT NOT NULL,
  134. source_system VARCHAR(50) NOT NULL,
  135. delivery_plan_no VARCHAR(100) NOT NULL,
  136. po_no VARCHAR(100) NOT NULL,
  137. po_line VARCHAR(50) NOT NULL,
  138. item_code VARCHAR(100) NOT NULL,
  139. supplier_code VARCHAR(100) NULL,
  140. supplier_name VARCHAR(200) NULL,
  141. schedule_qty DECIMAL(18,6) NULL,
  142. sent_qty DECIMAL(18,6) NULL,
  143. rest_qty DECIMAL(18,6) NULL,
  144. return_qty DECIMAL(18,6) NULL,
  145. request_date DATETIME NULL,
  146. need_date DATETIME NULL,
  147. submit_date DATETIME NULL,
  148. last_sent_date DATETIME NULL,
  149. status VARCHAR(50) NULL,
  150. source_biz_key VARCHAR(300) NOT NULL,
  151. sync_batch_id VARCHAR(64) NOT NULL,
  152. sync_time DATETIME NOT NULL,
  153. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  154. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  155. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  156. UNIQUE KEY uk_delivery_plan (tenant_id, delivery_plan_no),
  157. KEY idx_po_line (tenant_id, po_no, po_line),
  158. KEY idx_need_date (tenant_id, need_date),
  159. KEY idx_supplier_need (tenant_id, supplier_code, need_date)
  160. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准交货计划';
  161. CREATE TABLE IF NOT EXISTS mdp_std_delivery_result (
  162. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  163. tenant_id BIGINT NOT NULL,
  164. source_system VARCHAR(50) NOT NULL,
  165. delivery_no VARCHAR(100) NOT NULL,
  166. delivery_line VARCHAR(50) NULL,
  167. delivery_plan_no VARCHAR(100) NULL,
  168. po_no VARCHAR(100) NULL,
  169. po_line VARCHAR(50) NULL,
  170. item_code VARCHAR(100) NULL,
  171. delivery_qty DECIMAL(18,6) NULL,
  172. receipt_qty DECIMAL(18,6) NULL,
  173. return_qty DECIMAL(18,6) NULL,
  174. receipt_date DATETIME NULL,
  175. qc_status VARCHAR(50) NULL,
  176. event_time DATETIME NULL,
  177. source_biz_key VARCHAR(300) NOT NULL,
  178. sync_batch_id VARCHAR(64) NOT NULL,
  179. sync_time DATETIME NOT NULL,
  180. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  181. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  182. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  183. KEY idx_delivery (tenant_id, delivery_no),
  184. KEY idx_po_line (tenant_id, po_no, po_line),
  185. KEY idx_event_time (tenant_id, event_time)
  186. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准交货结果';
  187. CREATE TABLE IF NOT EXISTS mdp_std_material_readiness (
  188. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  189. tenant_id BIGINT NOT NULL,
  190. source_system VARCHAR(50) NOT NULL,
  191. work_order VARCHAR(100) NOT NULL,
  192. op_code VARCHAR(50) NULL,
  193. item_code VARCHAR(100) NULL,
  194. component_item_code VARCHAR(100) NOT NULL,
  195. required_qty DECIMAL(18,6) NULL,
  196. issued_qty DECIMAL(18,6) NULL,
  197. received_qty DECIMAL(18,6) NULL,
  198. available_qty DECIMAL(18,6) NULL,
  199. in_transit_qty DECIMAL(18,6) NULL,
  200. incoming_qty DECIMAL(18,6) NULL,
  201. shortage_qty DECIMAL(18,6) NULL,
  202. ready_status VARCHAR(50) NULL,
  203. need_date DATETIME NULL,
  204. supplier_code VARCHAR(100) NULL,
  205. source_biz_key VARCHAR(300) NOT NULL,
  206. sync_batch_id VARCHAR(64) NOT NULL,
  207. sync_time DATETIME NOT NULL,
  208. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  209. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  210. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  211. KEY idx_work_order (tenant_id, work_order),
  212. KEY idx_component_date (tenant_id, component_item_code, need_date),
  213. KEY idx_ready_status (tenant_id, ready_status)
  214. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准齐套结果';
  215. CREATE TABLE IF NOT EXISTS mdp_std_process_outsource_order (
  216. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  217. tenant_id BIGINT NOT NULL,
  218. source_system VARCHAR(50) NOT NULL,
  219. work_order VARCHAR(100) NOT NULL,
  220. op_code VARCHAR(50) NOT NULL,
  221. routing_code VARCHAR(100) NULL,
  222. supplier_code VARCHAR(100) NULL,
  223. po_no VARCHAR(100) NULL,
  224. po_line VARCHAR(50) NULL,
  225. order_qty DECIMAL(18,6) NULL,
  226. completed_qty DECIMAL(18,6) NULL,
  227. due_date DATETIME NULL,
  228. status VARCHAR(50) NULL,
  229. source_biz_key VARCHAR(300) NOT NULL,
  230. sync_batch_id VARCHAR(64) NOT NULL,
  231. sync_time DATETIME NOT NULL,
  232. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  233. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  234. UNIQUE KEY uk_source_key (tenant_id, source_system, source_biz_key),
  235. KEY idx_work_op (tenant_id, work_order, op_code),
  236. KEY idx_supplier_due (tenant_id, supplier_code, due_date),
  237. KEY idx_po_line (tenant_id, po_no, po_line)
  238. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3标准工序外协订单';
  239. CREATE TABLE IF NOT EXISTS dwd_supplier_delivery (
  240. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  241. tenant_id BIGINT NOT NULL,
  242. stat_date DATE NOT NULL,
  243. po_no VARCHAR(100) NOT NULL,
  244. po_line VARCHAR(50) NOT NULL,
  245. po_type VARCHAR(50) NULL,
  246. supplier_code VARCHAR(100) NULL,
  247. supplier_name VARCHAR(200) NULL,
  248. item_code VARCHAR(100) NOT NULL,
  249. item_name VARCHAR(200) NULL,
  250. order_qty DECIMAL(18,6) NULL,
  251. schedule_qty DECIMAL(18,6) NULL,
  252. delivery_qty DECIMAL(18,6) NULL,
  253. receipt_qty DECIMAL(18,6) NULL,
  254. return_qty DECIMAL(18,6) NULL,
  255. remaining_qty DECIMAL(18,6) NULL,
  256. due_date DATETIME NULL,
  257. need_date DATETIME NULL,
  258. last_delivery_date DATETIME NULL,
  259. last_receipt_date DATETIME NULL,
  260. delivery_status VARCHAR(50) NULL,
  261. risk_level VARCHAR(50) NULL,
  262. source_system VARCHAR(50) NULL,
  263. sync_batch_id VARCHAR(64) NULL,
  264. calc_time DATETIME NOT NULL,
  265. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  266. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  267. UNIQUE KEY uk_po_line_stat (tenant_id, po_no, po_line, stat_date),
  268. KEY idx_stat_date (tenant_id, stat_date),
  269. KEY idx_supplier_date (tenant_id, supplier_code, stat_date),
  270. KEY idx_item_date (tenant_id, item_code, stat_date)
  271. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3供应商采购交付宽表';
  272. CREATE TABLE IF NOT EXISTS dwd_material_readiness (
  273. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  274. tenant_id BIGINT NOT NULL,
  275. stat_date DATE NOT NULL,
  276. work_order VARCHAR(100) NOT NULL,
  277. op_code VARCHAR(50) NULL,
  278. parent_item_code VARCHAR(100) NULL,
  279. component_item_code VARCHAR(100) NOT NULL,
  280. component_item_name VARCHAR(200) NULL,
  281. required_qty DECIMAL(18,6) NULL,
  282. cumulative_required_qty DECIMAL(18,6) NULL,
  283. stock_available_qty DECIMAL(18,6) NULL,
  284. qc_pending_qty DECIMAL(18,6) NULL,
  285. in_transit_qty DECIMAL(18,6) NULL,
  286. delivery_reply_qty DECIMAL(18,6) NULL,
  287. available_qty DECIMAL(18,6) NULL,
  288. shortage_qty DECIMAL(18,6) NULL,
  289. ready_status VARCHAR(50) NULL,
  290. supplier_code VARCHAR(100) NULL,
  291. supplier_name VARCHAR(200) NULL,
  292. need_date DATETIME NULL,
  293. calc_batch_id VARCHAR(64) NOT NULL,
  294. calc_time DATETIME NOT NULL,
  295. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  296. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  297. UNIQUE KEY uk_work_component_stat (tenant_id, stat_date, work_order, op_code, component_item_code),
  298. KEY idx_work_order (tenant_id, work_order),
  299. KEY idx_item_date (tenant_id, component_item_code, stat_date),
  300. KEY idx_status_date (tenant_id, ready_status, stat_date)
  301. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3工单物料齐套宽表';
  302. CREATE TABLE IF NOT EXISTS dwd_material_shortage (
  303. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  304. tenant_id BIGINT NOT NULL,
  305. stat_date DATE NOT NULL,
  306. work_order VARCHAR(100) NOT NULL,
  307. op_code VARCHAR(50) NULL,
  308. component_item_code VARCHAR(100) NOT NULL,
  309. shortage_qty DECIMAL(18,6) NOT NULL DEFAULT 0,
  310. shortage_reason VARCHAR(200) NULL,
  311. expected_supply_date DATETIME NULL,
  312. supplier_code VARCHAR(100) NULL,
  313. related_po_no VARCHAR(100) NULL,
  314. related_delivery_plan_no VARCHAR(100) NULL,
  315. risk_level VARCHAR(50) NULL,
  316. calc_batch_id VARCHAR(64) NOT NULL,
  317. calc_time DATETIME NOT NULL,
  318. create_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
  319. update_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  320. KEY idx_work_order (tenant_id, work_order),
  321. KEY idx_item_date (tenant_id, component_item_code, stat_date),
  322. KEY idx_risk_date (tenant_id, risk_level, stat_date),
  323. KEY idx_supplier_date (tenant_id, supplier_code, stat_date)
  324. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='S3物料缺料事实表';