init.sql 69 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275
  1. -- =============================================
  2. -- OMS Database Initialization Script
  3. -- =============================================
  4. -- Create database
  5. CREATE DATABASE IF NOT EXISTS oms DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  6. USE oms;
  7. -- =============================================
  8. -- 1. 组织架构 (sys_user, sys_department, sys_role, sys_api_key, sys_operation_log, sys_notification, sys_message_template, sys_approval_flow)
  9. -- =============================================
  10. CREATE TABLE sys_user (
  11. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  12. username VARCHAR(128) NOT NULL COMMENT '用户名',
  13. password_hash VARCHAR(256) NOT NULL COMMENT '密码哈希',
  14. email VARCHAR(256) COMMENT '邮箱',
  15. phone VARCHAR(64) COMMENT '手机号',
  16. avatar VARCHAR(512) COMMENT '头像URL',
  17. name VARCHAR(128) NOT NULL COMMENT '姓名',
  18. role VARCHAR(32) NOT NULL COMMENT '角色',
  19. role_label VARCHAR(64) COMMENT '角色标签',
  20. workspace VARCHAR(128) COMMENT '工作区',
  21. department_id BIGINT COMMENT '部门ID',
  22. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  23. last_login_at DATETIME COMMENT '最后登录时间',
  24. last_login_ip VARCHAR(64) COMMENT '最后登录IP',
  25. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  26. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  27. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  28. created_by VARCHAR(64) COMMENT '创建人',
  29. updated_by VARCHAR(64) COMMENT '更新人',
  30. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  31. PRIMARY KEY (id),
  32. UNIQUE KEY uk_sys_user_username (username)
  33. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='系统用户表';
  34. CREATE TABLE sys_department (
  35. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  36. name VARCHAR(128) NOT NULL COMMENT '部门名称',
  37. parent_id BIGINT COMMENT '父部门ID',
  38. leader_id BIGINT COMMENT '负责人ID',
  39. leader_name VARCHAR(128) COMMENT '负责人姓名',
  40. description VARCHAR(512) COMMENT '部门描述',
  41. sort_order INT NOT NULL DEFAULT 0 COMMENT '排序',
  42. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  43. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  44. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  45. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  46. created_by VARCHAR(64) COMMENT '创建人',
  47. updated_by VARCHAR(64) COMMENT '更新人',
  48. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  49. PRIMARY KEY (id)
  50. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='部门表';
  51. CREATE TABLE sys_role (
  52. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  53. name VARCHAR(128) NOT NULL COMMENT '角色名称',
  54. description VARCHAR(512) COMMENT '角色描述',
  55. permissions JSON COMMENT '权限列表',
  56. bound_user_count INT NOT NULL DEFAULT 0 COMMENT '绑定用户数',
  57. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  58. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  59. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  60. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  61. created_by VARCHAR(64) COMMENT '创建人',
  62. updated_by VARCHAR(64) COMMENT '更新人',
  63. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  64. PRIMARY KEY (id)
  65. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='系统角色表';
  66. CREATE TABLE sys_api_key (
  67. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  68. name VARCHAR(128) NOT NULL COMMENT 'Key名称',
  69. `system` VARCHAR(64) NOT NULL COMMENT '所属系统',
  70. scope VARCHAR(512) COMMENT '权限范围',
  71. key_value VARCHAR(256) NOT NULL COMMENT 'Key值',
  72. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  73. expire_at DATETIME COMMENT '过期时间',
  74. last_used_at DATETIME COMMENT '最后使用时间',
  75. ip_whitelist VARCHAR(512) COMMENT 'IP白名单',
  76. remark VARCHAR(1024) COMMENT '备注',
  77. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  78. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  79. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  80. created_by VARCHAR(64) COMMENT '创建人',
  81. updated_by VARCHAR(64) COMMENT '更新人',
  82. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  83. PRIMARY KEY (id)
  84. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='API密钥表';
  85. CREATE TABLE sys_operation_log (
  86. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  87. module VARCHAR(64) NOT NULL COMMENT '模块',
  88. type VARCHAR(64) NOT NULL COMMENT '操作类型',
  89. object_id VARCHAR(64) COMMENT '对象ID',
  90. actor VARCHAR(128) NOT NULL COMMENT '操作人',
  91. actor_role VARCHAR(64) COMMENT '操作人角色',
  92. action VARCHAR(256) NOT NULL COMMENT '操作描述',
  93. result VARCHAR(64) COMMENT '操作结果',
  94. source_ip VARCHAR(64) COMMENT '来源IP',
  95. before_value TEXT COMMENT '变更前值',
  96. after_value TEXT COMMENT '变更后值',
  97. remark TEXT COMMENT '备注',
  98. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  99. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  100. PRIMARY KEY (id)
  101. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='系统操作日志表';
  102. CREATE TABLE sys_notification (
  103. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  104. user_id BIGINT NOT NULL COMMENT '用户ID',
  105. type VARCHAR(32) NOT NULL COMMENT '通知类型',
  106. title VARCHAR(256) NOT NULL COMMENT '通知标题',
  107. content TEXT COMMENT '通知内容',
  108. is_read TINYINT(1) NOT NULL DEFAULT 0 COMMENT '已读标记',
  109. read_at DATETIME COMMENT '阅读时间',
  110. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  111. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  112. PRIMARY KEY (id)
  113. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='系统通知表';
  114. CREATE TABLE sys_message_template (
  115. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  116. name VARCHAR(128) NOT NULL COMMENT '模板名称',
  117. type VARCHAR(32) NOT NULL COMMENT '模板类型',
  118. channel VARCHAR(64) NOT NULL COMMENT '渠道',
  119. content TEXT NOT NULL COMMENT '模板内容',
  120. variables JSON COMMENT '变量列表',
  121. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  122. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  123. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  124. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  125. created_by VARCHAR(64) COMMENT '创建人',
  126. updated_by VARCHAR(64) COMMENT '更新人',
  127. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  128. PRIMARY KEY (id)
  129. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='消息模板表';
  130. CREATE TABLE sys_approval_flow (
  131. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  132. name VARCHAR(128) NOT NULL COMMENT '流程名称',
  133. type VARCHAR(64) NOT NULL COMMENT '流程类型',
  134. nodes JSON NOT NULL COMMENT '流程节点',
  135. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  136. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  137. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  138. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  139. created_by VARCHAR(64) COMMENT '创建人',
  140. updated_by VARCHAR(64) COMMENT '更新人',
  141. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  142. PRIMARY KEY (id)
  143. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='审批流程表';
  144. -- =============================================
  145. -- 2. 商品中心
  146. -- =============================================
  147. CREATE TABLE product_category (
  148. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  149. name VARCHAR(128) NOT NULL COMMENT '类目名称',
  150. parent_id VARCHAR(64) COMMENT '父类目ID',
  151. level INT NOT NULL DEFAULT 0 COMMENT '层级',
  152. path VARCHAR(512) COMMENT '路径',
  153. sort_order INT NOT NULL DEFAULT 0 COMMENT '排序',
  154. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  155. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  156. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  157. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  158. created_by VARCHAR(64) COMMENT '创建人',
  159. updated_by VARCHAR(64) COMMENT '更新人',
  160. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  161. PRIMARY KEY (id)
  162. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='商品类目表';
  163. CREATE TABLE product (
  164. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  165. spu VARCHAR(128) NOT NULL COMMENT 'SPU编码',
  166. title VARCHAR(256) NOT NULL COMMENT '商品标题',
  167. subtitle VARCHAR(512) COMMENT '副标题',
  168. category_id BIGINT NOT NULL COMMENT '类目ID',
  169. brand VARCHAR(128) COMMENT '品牌',
  170. tags JSON COMMENT '标签列表',
  171. description TEXT COMMENT '商品描述',
  172. specs JSON COMMENT '规格列表',
  173. translations JSON COMMENT '翻译列表',
  174. channel_status VARCHAR(32) NOT NULL DEFAULT 'INACTIVE' COMMENT '渠道状态',
  175. status VARCHAR(32) NOT NULL DEFAULT 'DRAFT' COMMENT '商品状态',
  176. owner VARCHAR(128) COMMENT '负责人',
  177. sku_count INT NOT NULL DEFAULT 0 COMMENT 'SKU数量',
  178. image VARCHAR(512) COMMENT '主图URL',
  179. images JSON COMMENT '图片列表',
  180. videos JSON COMMENT '视频列表',
  181. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  182. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  183. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  184. created_by VARCHAR(64) COMMENT '创建人',
  185. updated_by VARCHAR(64) COMMENT '更新人',
  186. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  187. PRIMARY KEY (id),
  188. UNIQUE KEY uk_product_spu (spu)
  189. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='商品SPU表';
  190. CREATE TABLE product_sku (
  191. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  192. product_id BIGINT NOT NULL COMMENT '商品ID',
  193. sku VARCHAR(128) NOT NULL COMMENT 'SKU编码',
  194. spec_combo VARCHAR(512) NOT NULL COMMENT '规格组合',
  195. barcode VARCHAR(128) COMMENT '条形码',
  196. cost_price DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '成本价',
  197. suggest_price DECIMAL(20,4) COMMENT '建议零售价',
  198. weight DECIMAL(10,3) COMMENT '重量(克)',
  199. length DECIMAL(10,2) COMMENT '长度(cm)',
  200. width DECIMAL(10,2) COMMENT '宽度(cm)',
  201. height DECIMAL(10,2) COMMENT '高度(cm)',
  202. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT 'SKU状态',
  203. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  204. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  205. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  206. created_by VARCHAR(64) COMMENT '创建人',
  207. updated_by VARCHAR(64) COMMENT '更新人',
  208. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  209. PRIMARY KEY (id),
  210. UNIQUE KEY uk_product_sku_combo (product_id, sku)
  211. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='商品SKU表';
  212. CREATE TABLE channel_mapping (
  213. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  214. product_id BIGINT NOT NULL COMMENT '商品ID',
  215. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  216. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  217. internal_sku VARCHAR(128) NOT NULL COMMENT '内部SKU',
  218. channel_sku VARCHAR(256) NOT NULL COMMENT '渠道SKU',
  219. shop_name VARCHAR(256) COMMENT '店铺名称',
  220. channel_category VARCHAR(256) COMMENT '渠道类目',
  221. mapping_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '映射状态',
  222. validate_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '校验状态',
  223. last_sync_at DATETIME COMMENT '最后同步时间',
  224. last_validate_result VARCHAR(512) COMMENT '最后校验结果',
  225. channel_title VARCHAR(512) COMMENT '渠道商品标题',
  226. channel_description TEXT COMMENT '渠道商品描述',
  227. channel_price DECIMAL(20,4) COMMENT '渠道价格',
  228. channel_image VARCHAR(512) COMMENT '渠道商品图片',
  229. attribute_mappings JSON COMMENT '属性映射',
  230. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  231. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  232. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  233. created_by VARCHAR(64) COMMENT '创建人',
  234. updated_by VARCHAR(64) COMMENT '更新人',
  235. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  236. PRIMARY KEY (id),
  237. UNIQUE KEY uk_mapping_channel_sku (channel_id, internal_sku)
  238. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='渠道商品映射表';
  239. CREATE TABLE pricing_rule (
  240. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  241. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  242. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  243. currency VARCHAR(8) NOT NULL DEFAULT 'USD' COMMENT '币种',
  244. base_price DECIMAL(20,4) NOT NULL COMMENT '基础价格',
  245. channel_price DECIMAL(20,4) COMMENT '渠道价格',
  246. discount_price DECIMAL(20,4) COMMENT '折扣价格',
  247. channel_adjust_rule VARCHAR(128) COMMENT '渠道调价规则',
  248. exchange_source VARCHAR(64) COMMENT '汇率来源',
  249. warehouse_id BIGINT COMMENT '仓库ID',
  250. safe_stock_threshold INT COMMENT '安全库存阈值',
  251. warning_recipients VARCHAR(512) COMMENT '预警接收人',
  252. effective_time DATETIME NOT NULL COMMENT '生效时间',
  253. expire_time DATETIME COMMENT '失效时间',
  254. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '规则状态',
  255. modified_by VARCHAR(64) COMMENT '修改人',
  256. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  257. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  258. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  259. created_by VARCHAR(64) COMMENT '创建人',
  260. updated_by VARCHAR(64) COMMENT '更新人',
  261. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  262. PRIMARY KEY (id)
  263. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='定价规则表';
  264. -- =============================================
  265. -- 3. 渠道中心
  266. -- =============================================
  267. CREATE TABLE channel (
  268. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  269. channel_code VARCHAR(64) NOT NULL COMMENT '渠道编码',
  270. channel_name VARCHAR(128) NOT NULL COMMENT '渠道名称',
  271. shop_name VARCHAR(256) COMMENT '店铺名称',
  272. app_key VARCHAR(256) COMMENT '应用Key',
  273. app_secret VARCHAR(256) COMMENT '应用密钥',
  274. access_token VARCHAR(512) COMMENT '访问令牌',
  275. refresh_token VARCHAR(512) COMMENT '刷新令牌',
  276. token_expire_at DATETIME COMMENT '令牌过期时间',
  277. token_status VARCHAR(32) NOT NULL DEFAULT 'INVALID' COMMENT '令牌状态',
  278. webhook_url VARCHAR(512) COMMENT 'Webhook地址',
  279. webhook_secret VARCHAR(256) COMMENT 'Webhook密钥',
  280. sync_enabled TINYINT(1) NOT NULL DEFAULT 1 COMMENT '同步启用状态',
  281. sync_status VARCHAR(32) NOT NULL DEFAULT 'IDLE' COMMENT '同步状态',
  282. last_sync_at DATETIME COMMENT '最后同步时间',
  283. error_message VARCHAR(1024) COMMENT '错误信息',
  284. default_warehouse_id VARCHAR(64) COMMENT '默认仓库ID',
  285. remark VARCHAR(1024) COMMENT '备注',
  286. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  287. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  288. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  289. created_by VARCHAR(64) COMMENT '创建人',
  290. updated_by VARCHAR(64) COMMENT '更新人',
  291. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  292. PRIMARY KEY (id),
  293. UNIQUE KEY uk_channel_code (channel_code)
  294. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='销售渠道表';
  295. -- =============================================
  296. -- 4. 仓库物流
  297. -- =============================================
  298. CREATE TABLE warehouse (
  299. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  300. name VARCHAR(128) NOT NULL COMMENT '仓库名称',
  301. type VARCHAR(32) NOT NULL COMMENT '仓库类型',
  302. address VARCHAR(512) NOT NULL COMMENT '仓库地址',
  303. contact VARCHAR(128) COMMENT '联系人',
  304. phone VARCHAR(64) COMMENT '联系电话',
  305. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '仓库状态',
  306. manager VARCHAR(128) COMMENT '仓库管理员',
  307. remark VARCHAR(1024) COMMENT '备注',
  308. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  309. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  310. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  311. created_by VARCHAR(64) COMMENT '创建人',
  312. updated_by VARCHAR(64) COMMENT '更新人',
  313. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  314. PRIMARY KEY (id)
  315. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='仓库表';
  316. CREATE TABLE logistics_provider (
  317. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  318. name VARCHAR(128) NOT NULL COMMENT '物流商名称',
  319. channels JSON COMMENT '支持的渠道列表',
  320. billing_type VARCHAR(32) NOT NULL COMMENT '计费方式',
  321. tracking_url VARCHAR(512) COMMENT '追踪URL模板',
  322. contact VARCHAR(128) COMMENT '联系人',
  323. phone VARCHAR(64) COMMENT '联系电话',
  324. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '物流商状态',
  325. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  326. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  327. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  328. created_by VARCHAR(64) COMMENT '创建人',
  329. updated_by VARCHAR(64) COMMENT '更新人',
  330. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  331. PRIMARY KEY (id)
  332. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='物流商表';
  333. CREATE TABLE shipping_template (
  334. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  335. name VARCHAR(128) NOT NULL COMMENT '模板名称',
  336. carrier_id BIGINT NOT NULL COMMENT '物流商ID',
  337. carrier_name VARCHAR(128) NOT NULL COMMENT '物流商名称',
  338. billing_type VARCHAR(32) NOT NULL COMMENT '计费方式',
  339. first_weight DECIMAL(10,3) NOT NULL DEFAULT 0 COMMENT '首重',
  340. first_cost DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '首费',
  341. continue_weight DECIMAL(10,3) NOT NULL DEFAULT 0 COMMENT '续重',
  342. continue_cost DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '续费',
  343. remote_surcharge DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '偏远附加费',
  344. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '模板状态',
  345. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  346. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  347. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  348. created_by VARCHAR(64) COMMENT '创建人',
  349. updated_by VARCHAR(64) COMMENT '更新人',
  350. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  351. PRIMARY KEY (id)
  352. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='运费模板表';
  353. CREATE TABLE return_package (
  354. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  355. return_no VARCHAR(64) NOT NULL COMMENT '退件编号',
  356. original_tracking_no VARCHAR(256) COMMENT '原运单号',
  357. reason VARCHAR(1024) COMMENT '退件原因',
  358. status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '处理状态',
  359. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  360. handle_result VARCHAR(32) COMMENT '处理结果',
  361. images JSON COMMENT '图片列表',
  362. remark VARCHAR(1024) COMMENT '备注',
  363. handler_id BIGINT COMMENT '处理人ID',
  364. handler_name VARCHAR(128) COMMENT '处理人姓名',
  365. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  366. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  367. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  368. created_by VARCHAR(64) COMMENT '创建人',
  369. updated_by VARCHAR(64) COMMENT '更新人',
  370. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  371. PRIMARY KEY (id),
  372. UNIQUE KEY uk_return_no (return_no)
  373. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='退件表';
  374. -- =============================================
  375. -- 5. 库存中心
  376. -- =============================================
  377. CREATE TABLE inventory (
  378. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  379. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  380. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  381. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  382. available INT NOT NULL DEFAULT 0 COMMENT '可用库存',
  383. locked INT NOT NULL DEFAULT 0 COMMENT '锁定库存',
  384. inbound INT NOT NULL DEFAULT 0 COMMENT '在途库存',
  385. safe_stock INT NOT NULL DEFAULT 0 COMMENT '安全库存',
  386. warning_status VARCHAR(32) NOT NULL DEFAULT 'NORMAL' COMMENT '预警状态',
  387. last_change_at DATETIME COMMENT '最后变动时间',
  388. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  389. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  390. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  391. created_by VARCHAR(64) COMMENT '创建人',
  392. updated_by VARCHAR(64) COMMENT '更新人',
  393. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  394. PRIMARY KEY (id),
  395. UNIQUE KEY uk_inventory_sku_warehouse (sku_id, warehouse_id)
  396. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='库存表';
  397. CREATE TABLE inventory_log (
  398. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  399. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  400. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  401. source VARCHAR(64) NOT NULL COMMENT '变动来源',
  402. related_order_id BIGINT COMMENT '关联订单ID',
  403. related_order_no VARCHAR(64) COMMENT '关联订单号',
  404. operator VARCHAR(128) NOT NULL COMMENT '操作人',
  405. change_type VARCHAR(32) NOT NULL COMMENT '变动类型',
  406. quantity INT NOT NULL COMMENT '变动数量',
  407. before_qty INT NOT NULL COMMENT '变动前数量',
  408. after_qty INT NOT NULL COMMENT '变动后数量',
  409. reason VARCHAR(512) COMMENT '变动原因',
  410. remark VARCHAR(1024) COMMENT '备注',
  411. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  412. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  413. PRIMARY KEY (id)
  414. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='库存流水表';
  415. -- =============================================
  416. -- 6. 供应商采购
  417. -- =============================================
  418. CREATE TABLE supplier (
  419. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  420. name VARCHAR(128) NOT NULL COMMENT '供应商名称',
  421. company_name VARCHAR(256) COMMENT '公司名称',
  422. contact VARCHAR(128) COMMENT '联系人',
  423. phone VARCHAR(64) COMMENT '联系电话',
  424. email VARCHAR(256) COMMENT '邮箱',
  425. address VARCHAR(512) COMMENT '地址',
  426. bank_info VARCHAR(512) COMMENT '银行信息',
  427. tax_no VARCHAR(128) COMMENT '税号',
  428. contract_no VARCHAR(128) COMMENT '合同编号',
  429. settlement_type VARCHAR(32) NOT NULL DEFAULT 'CREDIT' COMMENT '结算方式',
  430. rating VARCHAR(16) COMMENT '评级',
  431. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '供应商状态',
  432. related_sku_count INT NOT NULL DEFAULT 0 COMMENT '关联SKU数量',
  433. remark VARCHAR(1024) COMMENT '备注',
  434. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  435. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  436. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  437. created_by VARCHAR(64) COMMENT '创建人',
  438. updated_by VARCHAR(64) COMMENT '更新人',
  439. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  440. PRIMARY KEY (id)
  441. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='供应商表';
  442. CREATE TABLE supply_capability (
  443. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  444. supplier_id BIGINT NOT NULL COMMENT '供应商ID',
  445. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  446. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  447. lead_time INT NOT NULL DEFAULT 0 COMMENT '交期(天)',
  448. moq INT NOT NULL DEFAULT 1 COMMENT '最小起订量',
  449. unit VARCHAR(32) NOT NULL DEFAULT 'PCS' COMMENT '单位',
  450. tier_prices JSON COMMENT '阶梯价格',
  451. is_default TINYINT(1) NOT NULL DEFAULT 0 COMMENT '是否默认',
  452. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  453. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  454. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  455. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  456. created_by VARCHAR(64) COMMENT '创建人',
  457. updated_by VARCHAR(64) COMMENT '更新人',
  458. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  459. PRIMARY KEY (id)
  460. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='供货能力表';
  461. CREATE TABLE purchase_order (
  462. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  463. po_no VARCHAR(64) NOT NULL COMMENT '采购单号',
  464. supplier_id BIGINT NOT NULL COMMENT '供应商ID',
  465. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  466. sku_count INT NOT NULL DEFAULT 0 COMMENT 'SKU数量',
  467. amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '采购金额',
  468. currency VARCHAR(8) NOT NULL DEFAULT 'CNY' COMMENT '币种',
  469. tax_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '税额',
  470. freight DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '运费',
  471. expected_date DATE COMMENT '预计到货日期',
  472. arrival_progress VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '到货进度',
  473. status VARCHAR(32) NOT NULL DEFAULT 'DRAFT' COMMENT '采购单状态',
  474. remark VARCHAR(1024) COMMENT '备注',
  475. creator_id BIGINT NOT NULL COMMENT '创建人ID',
  476. creator_name VARCHAR(128) COMMENT '创建人姓名',
  477. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  478. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  479. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  480. created_by VARCHAR(64) COMMENT '创建人',
  481. updated_by VARCHAR(64) COMMENT '更新人',
  482. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  483. PRIMARY KEY (id),
  484. UNIQUE KEY uk_po_no (po_no)
  485. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='采购单表';
  486. CREATE TABLE purchase_order_item (
  487. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  488. purchase_order_id BIGINT NOT NULL COMMENT '采购单ID',
  489. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  490. sku VARCHAR(128) NOT NULL COMMENT 'SKU编码',
  491. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  492. qty INT NOT NULL COMMENT '采购数量',
  493. price DECIMAL(20,4) NOT NULL COMMENT '采购单价',
  494. subtotal DECIMAL(20,4) NOT NULL COMMENT '小计金额',
  495. arrived_qty INT NOT NULL DEFAULT 0 COMMENT '已到货数量',
  496. qualified_qty INT NOT NULL DEFAULT 0 COMMENT '合格数量',
  497. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  498. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  499. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  500. PRIMARY KEY (id)
  501. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='采购单明细表';
  502. CREATE TABLE purchase_arrival (
  503. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  504. purchase_order_id BIGINT NOT NULL COMMENT '采购单ID',
  505. arrival_no VARCHAR(64) NOT NULL COMMENT '到货单号',
  506. arrived_at DATETIME NOT NULL COMMENT '到货时间',
  507. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  508. operator_id BIGINT NOT NULL COMMENT '操作人ID',
  509. operator_name VARCHAR(128) COMMENT '操作人姓名',
  510. remark VARCHAR(1024) COMMENT '备注',
  511. status VARCHAR(32) NOT NULL DEFAULT 'ARRIVED' COMMENT '状态',
  512. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  513. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  514. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  515. created_by VARCHAR(64) COMMENT '创建人',
  516. updated_by VARCHAR(64) COMMENT '更新人',
  517. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  518. PRIMARY KEY (id),
  519. UNIQUE KEY uk_arrival_no (arrival_no)
  520. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='到货确认表';
  521. CREATE TABLE purchase_arrival_item (
  522. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  523. arrival_id BIGINT NOT NULL COMMENT '到货单ID',
  524. purchase_order_item_id BIGINT NOT NULL COMMENT '采购单明细ID',
  525. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  526. expected_qty INT NOT NULL COMMENT '预期数量',
  527. actual_qty INT NOT NULL COMMENT '实际数量',
  528. qualified_qty INT NOT NULL DEFAULT 0 COMMENT '合格数量',
  529. unqualified_qty INT NOT NULL DEFAULT 0 COMMENT '不合格数量',
  530. iqc_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '质检状态',
  531. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  532. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  533. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  534. PRIMARY KEY (id)
  535. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='到货明细表';
  536. CREATE TABLE iqc (
  537. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  538. iqc_no VARCHAR(64) NOT NULL COMMENT '质检单号',
  539. supplier_id BIGINT NOT NULL COMMENT '供应商ID',
  540. arrival_id BIGINT NOT NULL COMMENT '到货单ID',
  541. arrival_no VARCHAR(64) NOT NULL COMMENT '到货单号',
  542. standard VARCHAR(256) COMMENT '质检标准',
  543. qualified_qty INT NOT NULL DEFAULT 0 COMMENT '合格数量',
  544. unqualified_qty INT NOT NULL DEFAULT 0 COMMENT '不合格数量',
  545. result VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '质检结果',
  546. inspector_id BIGINT COMMENT '质检员ID',
  547. inspector_name VARCHAR(128) COMMENT '质检员姓名',
  548. inspect_time DATETIME COMMENT '质检时间',
  549. remark VARCHAR(1024) COMMENT '备注',
  550. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  551. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  552. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  553. created_by VARCHAR(64) COMMENT '创建人',
  554. updated_by VARCHAR(64) COMMENT '更新人',
  555. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  556. PRIMARY KEY (id),
  557. UNIQUE KEY uk_iqc_no (iqc_no)
  558. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='来料质检表';
  559. CREATE TABLE replenishment_plan (
  560. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  561. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  562. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  563. warehouse_id BIGINT COMMENT '仓库ID',
  564. avg_daily_sales DECIMAL(12,4) NOT NULL DEFAULT 0 COMMENT '日均销量',
  565. safe_stock INT NOT NULL DEFAULT 0 COMMENT '安全库存',
  566. current_stock INT NOT NULL DEFAULT 0 COMMENT '当前库存',
  567. on_the_way INT NOT NULL DEFAULT 0 COMMENT '在途库存',
  568. suggested_qty INT NOT NULL DEFAULT 0 COMMENT '建议补货量',
  569. suggested_supplier_id VARCHAR(64) COMMENT '建议供应商ID',
  570. suggested_supplier_name VARCHAR(128) COMMENT '建议供应商名称',
  571. status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '计划状态',
  572. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  573. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  574. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  575. created_by VARCHAR(64) COMMENT '创建人',
  576. updated_by VARCHAR(64) COMMENT '更新人',
  577. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  578. PRIMARY KEY (id)
  579. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='备货计划表';
  580. CREATE TABLE purchase_request (
  581. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  582. request_no VARCHAR(64) NOT NULL COMMENT '需求单号',
  583. applicant_id BIGINT NOT NULL COMMENT '申请人ID',
  584. applicant_name VARCHAR(128) NOT NULL COMMENT '申请人姓名',
  585. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  586. sku VARCHAR(128) NOT NULL COMMENT 'SKU编码',
  587. qty INT NOT NULL COMMENT '需求数量',
  588. reason VARCHAR(1024) COMMENT '需求原因',
  589. urgency VARCHAR(32) NOT NULL DEFAULT 'NORMAL' COMMENT '紧急程度',
  590. status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '需求状态',
  591. related_order_id BIGINT COMMENT '关联订单ID',
  592. remark VARCHAR(1024) COMMENT '备注',
  593. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  594. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  595. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  596. created_by VARCHAR(64) COMMENT '创建人',
  597. updated_by VARCHAR(64) COMMENT '更新人',
  598. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  599. PRIMARY KEY (id),
  600. UNIQUE KEY uk_request_no (request_no)
  601. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='采购需求表';
  602. -- =============================================
  603. -- 7. 订单中心
  604. -- =============================================
  605. CREATE TABLE orders (
  606. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  607. order_no VARCHAR(64) NOT NULL COMMENT '订单号',
  608. channel_order_no VARCHAR(128) COMMENT '渠道订单号',
  609. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  610. order_status VARCHAR(32) NOT NULL DEFAULT 'CREATED' COMMENT '订单状态',
  611. shipping_status VARCHAR(32) NOT NULL DEFAULT 'UNSHIPPED' COMMENT '发货状态',
  612. payment_status VARCHAR(32) NOT NULL DEFAULT 'UNPAID' COMMENT '支付状态',
  613. refund_status VARCHAR(32) NOT NULL DEFAULT 'NONE' COMMENT '退款状态',
  614. exception_tag VARCHAR(64) COMMENT '异常标签',
  615. priority VARCHAR(32) NOT NULL DEFAULT 'NORMAL' COMMENT '优先级',
  616. paid_at DATETIME COMMENT '支付时间',
  617. shipped_at DATETIME COMMENT '发货时间',
  618. delivered_at DATETIME COMMENT '签收时间',
  619. buyer_id VARCHAR(64) COMMENT '买家ID',
  620. buyer VARCHAR(128) COMMENT '买家昵称',
  621. buyer_email VARCHAR(256) COMMENT '买家邮箱',
  622. buyer_phone VARCHAR(64) COMMENT '买家电话',
  623. buyer_country VARCHAR(64) COMMENT '买家国家',
  624. buyer_level VARCHAR(32) COMMENT '买家等级',
  625. buyer_tags JSON COMMENT '买家标签',
  626. buyer_register_time DATETIME COMMENT '注册时间',
  627. buyer_order_count INT NOT NULL DEFAULT 0 COMMENT '历史订单数',
  628. buyer_total_spent DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '历史消费金额',
  629. receiver_name VARCHAR(128) NOT NULL COMMENT '收货人姓名',
  630. receiver_phone VARCHAR(64) NOT NULL COMMENT '收货人电话',
  631. receiver_country VARCHAR(64) NOT NULL COMMENT '收货国家',
  632. receiver_state VARCHAR(128) COMMENT '收货省份',
  633. receiver_city VARCHAR(128) COMMENT '收货城市',
  634. receiver_district VARCHAR(128) COMMENT '收货区县',
  635. receiver_postal_code VARCHAR(32) COMMENT '收货邮编',
  636. receiver_address VARCHAR(512) NOT NULL COMMENT '详细地址',
  637. receiver_address_lang VARCHAR(64) COMMENT '地址语言',
  638. latitude DECIMAL(10,7) COMMENT '纬度',
  639. longitude DECIMAL(10,7) COMMENT '经度',
  640. transaction_id VARCHAR(128) COMMENT '交易流水号',
  641. payment_method VARCHAR(64) COMMENT '支付方式',
  642. payment_time DATETIME COMMENT '支付时间',
  643. currency VARCHAR(8) NOT NULL DEFAULT 'USD' COMMENT '订单币种',
  644. exchange_rate DECIMAL(20,6) NOT NULL DEFAULT 1 COMMENT '汇率',
  645. order_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '商品金额',
  646. order_amount_cny DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '人民币金额',
  647. tax_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '税额',
  648. shipping_fee DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '运费',
  649. discount_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '折扣金额',
  650. coupon_code VARCHAR(128) COMMENT '优惠券编码',
  651. coupon_discount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '优惠券折扣',
  652. actual_paid DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '实付金额',
  653. refund_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '退款金额',
  654. shipping_method VARCHAR(64) COMMENT '配送方式',
  655. carrier_id BIGINT COMMENT '物流商ID',
  656. carrier_name VARCHAR(128) COMMENT '物流商名称',
  657. tracking_no VARCHAR(256) COMMENT '运单号',
  658. tracking_url VARCHAR(512) COMMENT '追踪URL',
  659. warehouse_id BIGINT COMMENT '仓库ID',
  660. warehouse_location VARCHAR(128) COMMENT '库位',
  661. estimated_delivery DATE COMMENT '预计送达日期',
  662. weight DECIMAL(10,3) COMMENT '重量(kg)',
  663. length DECIMAL(10,2) COMMENT '长度(cm)',
  664. width DECIMAL(10,2) COMMENT '宽度(cm)',
  665. height DECIMAL(10,2) COMMENT '高度(cm)',
  666. utm_source VARCHAR(128) COMMENT 'UTM来源',
  667. utm_medium VARCHAR(128) COMMENT 'UTM媒介',
  668. utm_campaign VARCHAR(128) COMMENT 'UTM广告系列',
  669. utm_content VARCHAR(256) COMMENT 'UTM内容',
  670. utm_term VARCHAR(256) COMMENT 'UTM关键词',
  671. referrer_url VARCHAR(1024) COMMENT 'referrer来源',
  672. landing_page VARCHAR(512) COMMENT '落地页',
  673. ip VARCHAR(64) COMMENT 'IP地址',
  674. ip_country VARCHAR(64) COMMENT 'IP归属国',
  675. device VARCHAR(64) COMMENT '设备类型',
  676. browser VARCHAR(64) COMMENT '浏览器',
  677. os VARCHAR(64) COMMENT '操作系统',
  678. parent_order_id BIGINT COMMENT '母订单ID',
  679. merge_order_id BIGINT COMMENT '合并订单ID',
  680. related_order_id BIGINT COMMENT '关联订单ID',
  681. original_order_id BIGINT COMMENT '原订单ID(补发用)',
  682. handler_id BIGINT COMMENT '处理人ID',
  683. handler_name VARCHAR(128) COMMENT '处理人姓名',
  684. handler_group VARCHAR(64) COMMENT '处理组',
  685. order_tags JSON COMMENT '订单标签',
  686. internal_remark TEXT COMMENT '内部备注',
  687. buyer_remark TEXT COMMENT '买家备注',
  688. item_count INT NOT NULL DEFAULT 0 COMMENT '商品数量',
  689. total_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '订单总金额',
  690. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  691. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  692. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  693. created_by VARCHAR(64) COMMENT '创建人',
  694. updated_by VARCHAR(64) COMMENT '更新人',
  695. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  696. PRIMARY KEY (id),
  697. UNIQUE KEY uk_order_no (order_no)
  698. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='订单主表';
  699. CREATE TABLE order_item (
  700. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  701. order_id BIGINT NOT NULL COMMENT '订单ID',
  702. product_id BIGINT NOT NULL COMMENT '商品ID',
  703. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  704. sku VARCHAR(128) NOT NULL COMMENT 'SKU编码',
  705. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  706. product_image VARCHAR(512) COMMENT '商品图片',
  707. category_id VARCHAR(64) COMMENT '类目ID',
  708. category_name VARCHAR(128) COMMENT '类目名称',
  709. specs JSON COMMENT '规格信息',
  710. barcode VARCHAR(128) COMMENT '条形码',
  711. qty INT NOT NULL COMMENT '数量',
  712. price DECIMAL(20,4) NOT NULL COMMENT '单价',
  713. cost_price DECIMAL(20,4) NOT NULL COMMENT '成本价',
  714. profit DECIMAL(20,4) COMMENT '利润',
  715. profit_rate DECIMAL(8,4) COMMENT '利润率',
  716. subtotal DECIMAL(20,4) NOT NULL COMMENT '小计金额',
  717. weight DECIMAL(10,3) COMMENT '重量',
  718. available INT NOT NULL DEFAULT 0 COMMENT '可用库存',
  719. locked INT NOT NULL DEFAULT 0 COMMENT '锁定库存',
  720. in_transit INT NOT NULL DEFAULT 0 COMMENT '在途库存',
  721. reserved_qty INT NOT NULL DEFAULT 0 COMMENT '预留数量',
  722. shipped_qty INT NOT NULL DEFAULT 0 COMMENT '已发货数量',
  723. returned_qty INT NOT NULL DEFAULT 0 COMMENT '已退货数量',
  724. gift_flag TINYINT(1) NOT NULL DEFAULT 0 COMMENT '赠品标记',
  725. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  726. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  727. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  728. PRIMARY KEY (id)
  729. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='订单明细表';
  730. CREATE TABLE order_status_event (
  731. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  732. order_id BIGINT NOT NULL COMMENT '订单ID',
  733. status VARCHAR(64) NOT NULL COMMENT '状态',
  734. time DATETIME NOT NULL COMMENT '时间',
  735. title VARCHAR(256) NOT NULL COMMENT '标题',
  736. summary VARCHAR(1024) COMMENT '摘要',
  737. type VARCHAR(64) NOT NULL COMMENT '类型',
  738. operator VARCHAR(128) COMMENT '操作人',
  739. operator_role VARCHAR(64) COMMENT '操作人角色',
  740. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  741. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  742. PRIMARY KEY (id)
  743. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='订单状态事件表';
  744. CREATE TABLE order_operation_log (
  745. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  746. order_id BIGINT COMMENT '订单ID',
  747. module VARCHAR(64) NOT NULL COMMENT '模块',
  748. type VARCHAR(64) NOT NULL COMMENT '操作类型',
  749. object_id VARCHAR(64) COMMENT '对象ID',
  750. time DATETIME NOT NULL COMMENT '操作时间',
  751. title VARCHAR(256) NOT NULL COMMENT '操作标题',
  752. content TEXT COMMENT '操作内容',
  753. operator VARCHAR(128) NOT NULL COMMENT '操作人',
  754. operator_role VARCHAR(64) COMMENT '操作人角色',
  755. result VARCHAR(64) COMMENT '操作结果',
  756. source_ip VARCHAR(64) COMMENT '来源IP',
  757. before_value TEXT COMMENT '变更前值',
  758. after_value TEXT COMMENT '变更后值',
  759. remark TEXT COMMENT '备注',
  760. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  761. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  762. PRIMARY KEY (id)
  763. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='订单操作日志表';
  764. CREATE TABLE shipping_order (
  765. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  766. shipment_no VARCHAR(64) NOT NULL COMMENT '发货单号',
  767. order_id BIGINT NOT NULL COMMENT '订单ID',
  768. order_no VARCHAR(64) NOT NULL COMMENT '订单号',
  769. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  770. items JSON NOT NULL COMMENT '发货商品明细',
  771. sku_count INT NOT NULL DEFAULT 0 COMMENT 'SKU数量',
  772. expected_qty INT NOT NULL DEFAULT 0 COMMENT '预期数量',
  773. actual_qty INT NOT NULL DEFAULT 0 COMMENT '实际数量',
  774. carrier_id BIGINT COMMENT '物流商ID',
  775. carrier_name VARCHAR(128) COMMENT '物流商名称',
  776. tracking_no VARCHAR(256) COMMENT '运单号',
  777. shipping_status VARCHAR(32) NOT NULL DEFAULT 'PENDING_PICK' COMMENT '发货状态',
  778. return_status VARCHAR(32) NOT NULL DEFAULT 'NOT_RETURNED' COMMENT '回传状态',
  779. return_tracking_no VARCHAR(256) COMMENT '退件运单号',
  780. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  781. shipped_at DATETIME COMMENT '发货时间',
  782. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  783. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  784. created_by VARCHAR(64) COMMENT '创建人',
  785. updated_by VARCHAR(64) COMMENT '更新人',
  786. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  787. PRIMARY KEY (id),
  788. UNIQUE KEY uk_shipment_no (shipment_no)
  789. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='发货单表';
  790. -- =============================================
  791. -- 8. 售后中心
  792. -- =============================================
  793. CREATE TABLE after_sale (
  794. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  795. after_sale_no VARCHAR(64) NOT NULL COMMENT '售后单号',
  796. order_id BIGINT NOT NULL COMMENT '订单ID',
  797. order_no VARCHAR(64) NOT NULL COMMENT '订单号',
  798. buyer_id VARCHAR(64) COMMENT '买家ID',
  799. buyer VARCHAR(128) NOT NULL COMMENT '买家姓名',
  800. type VARCHAR(32) NOT NULL COMMENT '售后类型',
  801. amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '申请金额',
  802. audit_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '审核状态',
  803. refund_status VARCHAR(32) NOT NULL DEFAULT 'NONE' COMMENT '退款状态',
  804. reason VARCHAR(1024) NOT NULL COMMENT '申请原因',
  805. responsibility VARCHAR(64) COMMENT '责任方',
  806. refund_amount DECIMAL(20,4) COMMENT '实际退款金额',
  807. refund_method VARCHAR(64) COMMENT '退款方式',
  808. return_tracking_no VARCHAR(256) COMMENT '退货运单号',
  809. return_carrier VARCHAR(128) COMMENT '退货物流商',
  810. resend_warehouse_id BIGINT COMMENT '补发仓库ID',
  811. resend_sku_id BIGINT COMMENT '补发SKU ID',
  812. resend_order_id BIGINT COMMENT '补发订单ID',
  813. audit_remark TEXT COMMENT '审核备注',
  814. images JSON COMMENT '图片列表',
  815. handler_id BIGINT COMMENT '处理人ID',
  816. handler_name VARCHAR(128) COMMENT '处理人姓名',
  817. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  818. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  819. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  820. created_by VARCHAR(64) COMMENT '创建人',
  821. updated_by VARCHAR(64) COMMENT '更新人',
  822. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  823. PRIMARY KEY (id),
  824. UNIQUE KEY uk_after_sale_no (after_sale_no)
  825. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='售后表';
  826. -- =============================================
  827. -- 9. 财务中心
  828. -- =============================================
  829. CREATE TABLE finance_payment (
  830. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  831. order_id BIGINT COMMENT '订单ID',
  832. payment_no VARCHAR(64) NOT NULL COMMENT '收款单号',
  833. channel_order_no VARCHAR(128) COMMENT '渠道订单号',
  834. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  835. shop_name VARCHAR(256) COMMENT '店铺名称',
  836. currency VARCHAR(8) NOT NULL COMMENT '币种',
  837. amount DECIMAL(20,4) NOT NULL COMMENT '收款金额',
  838. fee DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '手续费',
  839. pay_method VARCHAR(64) COMMENT '支付方式',
  840. pay_time DATETIME COMMENT '支付时间',
  841. transaction_no VARCHAR(128) COMMENT '交易流水号',
  842. reconcile_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '对账状态',
  843. reconcile_time DATETIME COMMENT '对账时间',
  844. remark VARCHAR(1024) COMMENT '备注',
  845. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  846. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  847. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  848. created_by VARCHAR(64) COMMENT '创建人',
  849. updated_by VARCHAR(64) COMMENT '更新人',
  850. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  851. PRIMARY KEY (id),
  852. UNIQUE KEY uk_payment_no (payment_no)
  853. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='收款表';
  854. CREATE TABLE finance_refund (
  855. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  856. order_id BIGINT NOT NULL COMMENT '订单ID',
  857. refund_no VARCHAR(64) NOT NULL COMMENT '退款单号',
  858. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  859. channel_order_no VARCHAR(128) COMMENT '渠道订单号',
  860. currency VARCHAR(8) NOT NULL COMMENT '币种',
  861. refund_amount DECIMAL(20,4) NOT NULL COMMENT '退款金额',
  862. refund_method VARCHAR(64) COMMENT '退款方式',
  863. refund_time DATETIME COMMENT '退款时间',
  864. refund_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '退款状态',
  865. channel_refund_no VARCHAR(128) COMMENT '渠道退款单号',
  866. reason VARCHAR(1024) COMMENT '退款原因',
  867. remark VARCHAR(1024) COMMENT '备注',
  868. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  869. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  870. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  871. created_by VARCHAR(64) COMMENT '创建人',
  872. updated_by VARCHAR(64) COMMENT '更新人',
  873. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  874. PRIMARY KEY (id),
  875. UNIQUE KEY uk_refund_no (refund_no)
  876. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='退款表';
  877. CREATE TABLE supplier_settlement (
  878. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  879. settlement_no VARCHAR(64) NOT NULL COMMENT '结算单号',
  880. supplier_id BIGINT NOT NULL COMMENT '供应商ID',
  881. period VARCHAR(32) NOT NULL COMMENT '结算周期',
  882. purchase_order_ids JSON COMMENT '关联采购单ID列表',
  883. payable_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '应付金额',
  884. paid_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '已付金额',
  885. status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '结算状态',
  886. paid_at DATETIME COMMENT '支付时间',
  887. remark VARCHAR(1024) COMMENT '备注',
  888. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  889. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  890. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  891. created_by VARCHAR(64) COMMENT '创建人',
  892. updated_by VARCHAR(64) COMMENT '更新人',
  893. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  894. PRIMARY KEY (id),
  895. UNIQUE KEY uk_settlement_no (settlement_no)
  896. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='供应商结算表';
  897. CREATE TABLE invoice (
  898. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  899. invoice_no VARCHAR(64) NOT NULL COMMENT '发票号',
  900. invoice_type VARCHAR(32) NOT NULL COMMENT '发票类型',
  901. order_id BIGINT COMMENT '订单ID',
  902. buyer_name VARCHAR(256) NOT NULL COMMENT '购买方名称',
  903. buyer_tax_no VARCHAR(128) COMMENT '购买方税号',
  904. seller_name VARCHAR(256) NOT NULL COMMENT '销售方名称',
  905. amount DECIMAL(20,4) NOT NULL COMMENT '发票金额',
  906. tax_rate DECIMAL(8,4) NOT NULL COMMENT '税率',
  907. tax_amount DECIMAL(20,4) NOT NULL COMMENT '税额',
  908. invoice_date DATE NOT NULL COMMENT '开票日期',
  909. status VARCHAR(32) NOT NULL DEFAULT 'DRAFT' COMMENT '发票状态',
  910. remark VARCHAR(1024) COMMENT '备注',
  911. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  912. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  913. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  914. created_by VARCHAR(64) COMMENT '创建人',
  915. updated_by VARCHAR(64) COMMENT '更新人',
  916. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  917. PRIMARY KEY (id),
  918. UNIQUE KEY uk_invoice_no (invoice_no)
  919. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='发票表';
  920. -- =============================================
  921. -- 10. 客服中心
  922. -- =============================================
  923. CREATE TABLE ticket (
  924. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  925. ticket_no VARCHAR(64) NOT NULL COMMENT '工单编号',
  926. title VARCHAR(256) NOT NULL COMMENT '工单标题',
  927. type VARCHAR(32) NOT NULL COMMENT '工单类型',
  928. priority VARCHAR(32) NOT NULL DEFAULT 'MEDIUM' COMMENT '优先级',
  929. status VARCHAR(32) NOT NULL DEFAULT 'OPEN' COMMENT '工单状态',
  930. creator VARCHAR(128) NOT NULL COMMENT '创建人',
  931. assignee_id BIGINT COMMENT '受理人ID',
  932. assignee_name VARCHAR(128) COMMENT '受理人姓名',
  933. related_order_id BIGINT COMMENT '关联订单ID',
  934. related_order_no VARCHAR(64) COMMENT '关联订单号',
  935. content TEXT NOT NULL COMMENT '工单内容',
  936. images JSON COMMENT '图片列表',
  937. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  938. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  939. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  940. created_by VARCHAR(64) COMMENT '创建人',
  941. updated_by VARCHAR(64) COMMENT '更新人',
  942. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  943. PRIMARY KEY (id),
  944. UNIQUE KEY uk_ticket_no (ticket_no)
  945. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='工单表';
  946. CREATE TABLE satisfaction (
  947. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  948. order_id BIGINT NOT NULL COMMENT '订单ID',
  949. order_no VARCHAR(64) NOT NULL COMMENT '订单号',
  950. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  951. source VARCHAR(64) COMMENT '来源',
  952. buyer VARCHAR(128) COMMENT '买家',
  953. product_title VARCHAR(256) COMMENT '商品标题',
  954. rating INT NOT NULL COMMENT '评分',
  955. content TEXT COMMENT '评价内容',
  956. reply TEXT COMMENT '回复内容',
  957. handle_status VARCHAR(32) NOT NULL DEFAULT 'PENDING' COMMENT '处理状态',
  958. cs_id BIGINT COMMENT '客服ID',
  959. cs_name VARCHAR(128) COMMENT '客服姓名',
  960. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  961. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  962. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  963. PRIMARY KEY (id)
  964. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='满意度评价表';
  965. -- =============================================
  966. -- 11. AI客服
  967. -- =============================================
  968. CREATE TABLE ai_channel (
  969. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  970. name VARCHAR(128) NOT NULL COMMENT '渠道名称',
  971. code VARCHAR(64) NOT NULL COMMENT '渠道编码',
  972. icon VARCHAR(64) COMMENT '图标',
  973. enabled TINYINT(1) NOT NULL DEFAULT 1 COMMENT '是否启用',
  974. robot_name VARCHAR(128) COMMENT '机器人名称',
  975. robot_enabled TINYINT(1) NOT NULL DEFAULT 1 COMMENT '机器人是否启用',
  976. auto_transfer_threshold INT NOT NULL DEFAULT 300 COMMENT '自动转人工阈值(秒)',
  977. priority INT NOT NULL DEFAULT 0 COMMENT '优先级',
  978. welcome_message TEXT COMMENT '欢迎语',
  979. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  980. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  981. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  982. created_by VARCHAR(64) COMMENT '创建人',
  983. updated_by VARCHAR(64) COMMENT '更新人',
  984. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  985. PRIMARY KEY (id),
  986. UNIQUE KEY uk_ai_channel_code (code)
  987. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='AI渠道配置表';
  988. CREATE TABLE knowledge_category (
  989. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  990. name VARCHAR(128) NOT NULL COMMENT '分类名称',
  991. parent_id VARCHAR(64) COMMENT '父分类ID',
  992. sort_order INT NOT NULL DEFAULT 0 COMMENT '排序',
  993. count INT NOT NULL DEFAULT 0 COMMENT '条目数量',
  994. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  995. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  996. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  997. created_by VARCHAR(64) COMMENT '创建人',
  998. updated_by VARCHAR(64) COMMENT '更新人',
  999. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1000. PRIMARY KEY (id)
  1001. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='知识库分类表';
  1002. CREATE TABLE knowledge_base (
  1003. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1004. category_id BIGINT NOT NULL COMMENT '分类ID',
  1005. category_name VARCHAR(128) NOT NULL COMMENT '分类名称',
  1006. keywords JSON COMMENT '关键词列表',
  1007. question VARCHAR(512) NOT NULL COMMENT '问题',
  1008. answer TEXT NOT NULL COMMENT '回答',
  1009. clicks INT NOT NULL DEFAULT 0 COMMENT '点击次数',
  1010. ai_score DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT 'AI评分',
  1011. status VARCHAR(32) NOT NULL DEFAULT 'ENABLED' COMMENT '状态',
  1012. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1013. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1014. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1015. created_by VARCHAR(64) COMMENT '创建人',
  1016. updated_by VARCHAR(64) COMMENT '更新人',
  1017. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1018. PRIMARY KEY (id)
  1019. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='知识库表';
  1020. CREATE TABLE auto_reply_rule (
  1021. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1022. name VARCHAR(128) NOT NULL COMMENT '规则名称',
  1023. priority INT NOT NULL DEFAULT 0 COMMENT '优先级',
  1024. trigger_type VARCHAR(32) NOT NULL COMMENT '触发类型',
  1025. keywords JSON COMMENT '关键词列表',
  1026. match_mode VARCHAR(32) NOT NULL DEFAULT 'CONTAIN' COMMENT '匹配模式',
  1027. responses JSON NOT NULL COMMENT '回复列表',
  1028. status VARCHAR(32) NOT NULL DEFAULT 'ENABLED' COMMENT '规则状态',
  1029. hit_count INT NOT NULL DEFAULT 0 COMMENT '命中次数',
  1030. accuracy DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '准确率',
  1031. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1032. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1033. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1034. created_by VARCHAR(64) COMMENT '创建人',
  1035. updated_by VARCHAR(64) COMMENT '更新人',
  1036. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1037. PRIMARY KEY (id)
  1038. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='自动回复规则表';
  1039. CREATE TABLE chat_session (
  1040. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1041. visitor_id BIGINT NOT NULL COMMENT '访客ID',
  1042. visitor_name VARCHAR(128) COMMENT '访客名称',
  1043. visitor_avatar VARCHAR(512) COMMENT '访客头像',
  1044. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  1045. shop_name VARCHAR(256) COMMENT '店铺名称',
  1046. ai_handled TINYINT(1) NOT NULL DEFAULT 1 COMMENT 'AI处理标记',
  1047. agent_id BIGINT COMMENT '客服ID',
  1048. agent_name VARCHAR(128) COMMENT '客服名称',
  1049. satisfaction INT COMMENT '满意度评分',
  1050. status VARCHAR(32) NOT NULL DEFAULT 'WAITING' COMMENT '会话状态',
  1051. source VARCHAR(64) COMMENT '来源',
  1052. device VARCHAR(64) COMMENT '设备',
  1053. location VARCHAR(128) COMMENT '位置',
  1054. intent VARCHAR(128) COMMENT '意图',
  1055. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1056. ended_at DATETIME COMMENT '结束时间',
  1057. last_message_at DATETIME NOT NULL COMMENT '最后消息时间',
  1058. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1059. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1060. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1061. PRIMARY KEY (id)
  1062. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='AI会话表';
  1063. CREATE TABLE chat_message (
  1064. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1065. session_id BIGINT NOT NULL COMMENT '会话ID',
  1066. role VARCHAR(32) NOT NULL COMMENT '发送者角色',
  1067. content TEXT NOT NULL COMMENT '消息内容',
  1068. attachments JSON COMMENT '附件列表',
  1069. timestamp DATETIME NOT NULL COMMENT '发送时间',
  1070. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1071. PRIMARY KEY (id)
  1072. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='AI消息表';
  1073. CREATE TABLE service_performance (
  1074. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1075. agent_id BIGINT NOT NULL COMMENT '客服ID',
  1076. agent_name VARCHAR(128) NOT NULL COMMENT '客服名称',
  1077. agent_avatar VARCHAR(512) COMMENT '客服头像',
  1078. department VARCHAR(128) COMMENT '部门',
  1079. handle_count INT NOT NULL DEFAULT 0 COMMENT '处理数量',
  1080. ai_assist_count INT NOT NULL DEFAULT 0 COMMENT 'AI辅助次数',
  1081. avg_response_time DECIMAL(10,2) NOT NULL DEFAULT 0 COMMENT '平均响应时间(秒)',
  1082. avg_first_response_time DECIMAL(10,2) NOT NULL DEFAULT 0 COMMENT '平均首次响应时间(秒)',
  1083. satisfaction DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '满意度',
  1084. solve_rate DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '解决率',
  1085. date DATE NOT NULL COMMENT '统计日期',
  1086. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1087. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1088. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1089. PRIMARY KEY (id)
  1090. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='客服绩效表';
  1091. -- =============================================
  1092. -- 12. 营销中心
  1093. -- =============================================
  1094. CREATE TABLE promotion (
  1095. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1096. name VARCHAR(128) NOT NULL COMMENT '活动名称',
  1097. type VARCHAR(32) NOT NULL COMMENT '活动类型',
  1098. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  1099. shop_name VARCHAR(256) COMMENT '店铺名称',
  1100. start_time DATETIME NOT NULL COMMENT '开始时间',
  1101. end_time DATETIME NOT NULL COMMENT '结束时间',
  1102. status VARCHAR(32) NOT NULL DEFAULT 'DRAFT' COMMENT '活动状态',
  1103. discount VARCHAR(64) COMMENT '折扣信息',
  1104. min_amount DECIMAL(20,4) COMMENT '最低消费金额',
  1105. products JSON COMMENT '参与商品列表',
  1106. remark VARCHAR(1024) COMMENT '备注',
  1107. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1108. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1109. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1110. created_by VARCHAR(64) COMMENT '创建人',
  1111. updated_by VARCHAR(64) COMMENT '更新人',
  1112. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1113. PRIMARY KEY (id)
  1114. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='促销活动表';
  1115. CREATE TABLE coupon (
  1116. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1117. name VARCHAR(128) NOT NULL COMMENT '优惠券名称',
  1118. coupon_type VARCHAR(32) NOT NULL COMMENT '优惠券类型',
  1119. value DECIMAL(20,4) NOT NULL COMMENT '优惠值',
  1120. min_amount DECIMAL(20,4) NOT NULL DEFAULT 0 COMMENT '最低消费金额',
  1121. total_count INT NOT NULL DEFAULT 0 COMMENT '发放总量',
  1122. used_count INT NOT NULL DEFAULT 0 COMMENT '已使用数量',
  1123. used_rate DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '使用率',
  1124. valid_start DATETIME NOT NULL COMMENT '有效期开始',
  1125. valid_end DATETIME NOT NULL COMMENT '有效期结束',
  1126. status VARCHAR(32) NOT NULL DEFAULT 'DRAFT' COMMENT '优惠券状态',
  1127. channels JSON COMMENT '可用渠道列表',
  1128. remark VARCHAR(1024) COMMENT '备注',
  1129. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1130. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1131. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1132. created_by VARCHAR(64) COMMENT '创建人',
  1133. updated_by VARCHAR(64) COMMENT '更新人',
  1134. deleted TINYINT(1) NOT NULL DEFAULT 0 COMMENT '软删除标记',
  1135. PRIMARY KEY (id)
  1136. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='优惠券表';
  1137. CREATE TABLE price_watch (
  1138. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1139. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  1140. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  1141. channel_id BIGINT NOT NULL COMMENT '渠道ID',
  1142. shop_name VARCHAR(256) COMMENT '店铺名称',
  1143. local_price DECIMAL(20,4) NOT NULL COMMENT '本地价格',
  1144. competitor_price DECIMAL(20,4) NOT NULL COMMENT '竞品价格',
  1145. price_diff DECIMAL(20,4) NOT NULL COMMENT '价格差异',
  1146. competitor_name VARCHAR(128) COMMENT '竞品名称',
  1147. competitor_url VARCHAR(512) COMMENT '竞品链接',
  1148. last_update DATETIME NOT NULL COMMENT '最后更新时间',
  1149. alert_status VARCHAR(32) NOT NULL DEFAULT 'NORMAL' COMMENT '预警状态',
  1150. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1151. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1152. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1153. PRIMARY KEY (id)
  1154. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='价格监控表';
  1155. CREATE TABLE supplier_performance (
  1156. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1157. supplier_id BIGINT NOT NULL COMMENT '供应商ID',
  1158. supplier_name VARCHAR(128) NOT NULL COMMENT '供应商名称',
  1159. contact VARCHAR(128) COMMENT '联系人',
  1160. phone VARCHAR(64) COMMENT '联系电话',
  1161. delivery_rate DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '交货率',
  1162. quality_rate DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '质量合格率',
  1163. response_time DECIMAL(10,2) NOT NULL DEFAULT 0 COMMENT '响应时间(小时)',
  1164. return_rate DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '退货率',
  1165. price_score DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '价格评分',
  1166. overall_score DECIMAL(5,2) NOT NULL DEFAULT 0 COMMENT '综合评分',
  1167. rating_level VARCHAR(16) COMMENT '评级',
  1168. status VARCHAR(32) NOT NULL DEFAULT 'ACTIVE' COMMENT '状态',
  1169. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1170. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1171. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1172. PRIMARY KEY (id)
  1173. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='供应商绩效表';
  1174. -- =============================================
  1175. -- 13. 报表中心
  1176. -- =============================================
  1177. CREATE TABLE inventory_turnover (
  1178. id BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  1179. sku_id BIGINT NOT NULL COMMENT 'SKU ID',
  1180. product_title VARCHAR(256) NOT NULL COMMENT '商品标题',
  1181. warehouse_id BIGINT NOT NULL COMMENT '仓库ID',
  1182. turnover_days INT NOT NULL DEFAULT 0 COMMENT '周转天数',
  1183. sales_qty INT NOT NULL DEFAULT 0 COMMENT '销售数量',
  1184. avg_stock DECIMAL(12,2) NOT NULL DEFAULT 0 COMMENT '平均库存',
  1185. alert_status VARCHAR(32) NOT NULL DEFAULT 'NORMAL' COMMENT '预警状态',
  1186. date DATE NOT NULL COMMENT '统计日期',
  1187. tenant_id VARCHAR(64) NOT NULL DEFAULT 'DEFAULT' COMMENT '租户ID',
  1188. created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  1189. updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  1190. PRIMARY KEY (id)
  1191. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='库存周转表';
  1192. -- =============================================
  1193. -- 初始化数据
  1194. -- =============================================
  1195. -- 初始化超级管理员 (password: admin123)
  1196. INSERT INTO sys_user (username, password_hash, email, name, role, role_label, workspace, status, tenant_id) VALUES
  1197. ('admin', '$2a$10$AKKZ1KuZW6lsiXk3ecbrn.Y5O8yucLF1/he37JoLsibfh3cVE4cSS', 'admin@oms.com', '系统管理员', 'ADMIN', '超级管理员', '全栈', 'ACTIVE', 'DEFAULT');
  1198. -- 初始化默认角色
  1199. INSERT INTO sys_role (name, description, permissions, bound_user_count, status, tenant_id) VALUES
  1200. ('ADMIN', '超级管理员', '["*:*:*"]', 1, 'ACTIVE', 'DEFAULT'),
  1201. ('MANAGER', '运营经理', '["product:*", "order:*", "inventory:*"]', 0, 'ACTIVE', 'DEFAULT'),
  1202. ('OPERATOR', '运营专员', '["product:read", "order:*"]', 0, 'ACTIVE', 'DEFAULT'),
  1203. ('PROCUREMENT', '采购员', '["purchase:*"]', 0, 'ACTIVE', 'DEFAULT'),
  1204. ('WAREHOUSE', '仓库管理员', '["inventory:*", "warehouse:*"]', 0, 'ACTIVE', 'DEFAULT'),
  1205. ('FINANCE', '财务', '["finance:*"]', 0, 'ACTIVE', 'DEFAULT'),
  1206. ('CUSTOMER_SERVICE', '客服', '["after-sale:*", "ticket:*"]', 0, 'ACTIVE', 'DEFAULT');