init.sql 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. CREATE DATABASE IF NOT EXISTS recycle DEFAULT CHARSET utf8mb4;
  2. USE recycle;
  3. /* ================= 分类 ================= */
  4. CREATE TABLE t_chx_category (
  5. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  6. category_id BIGINT NOT NULL,
  7. name VARCHAR(60) NOT NULL,
  8. create_time DATETIME DEFAULT CURRENT_TIMESTAMP
  9. );
  10. /* ================= 机型 ================= */
  11. CREATE TABLE t_machine (
  12. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  13. code VARCHAR(32),
  14. type_id BIGINT,
  15. type_name VARCHAR(100),
  16. brand_id BIGINT,
  17. brand_name VARCHAR(100),
  18. machine_id BIGINT,
  19. name VARCHAR(100),
  20. shrink_name VARCHAR(100),
  21. create_time DATETIME DEFAULT CURRENT_TIMESTAMP
  22. );
  23. /* ================= 机型模板 ================= */
  24. CREATE TABLE machine_temp (
  25. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  26. machine_id BIGINT,
  27. temp_type VARCHAR(32) DEFAULT '00',
  28. estimate_packet TEXT,
  29. base_template_id BIGINT NULL,
  30. is_custom TINYINT DEFAULT 0,
  31. create_time DATETIME DEFAULT CURRENT_TIMESTAMP,
  32. update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
  33. );
  34. /* ================= 设备情况项 ================= */
  35. CREATE TABLE release_option (
  36. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  37. step_id BIGINT COMMENT '1物品信息 2成色情况 3功能情况',
  38. step_name VARCHAR(50),
  39. option_key_id BIGINT,
  40. option_key_name VARCHAR(60),
  41. option_id BIGINT,
  42. option_name VARCHAR(60),
  43. create_time DATETIME DEFAULT CURRENT_TIMESTAMP
  44. update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
  45. );
  46. /* ================= step1设备选项 ================= */
  47. CREATE TABLE step1_attr (
  48. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  49. base_template_id BIGINT NOT NULL COMMENT '基础模板ID:99181 / 99198 / 99197',
  50. step TINYINT DEFAULT 1 COMMENT '固定为 step=1',
  51. attr_key VARCHAR(64) NOT NULL COMMENT 'capacity / color / channel / warranty',
  52. attr_name VARCHAR(64) NOT NULL COMMENT '容量 / 颜色 / 购买渠道 / 保修',
  53. value_id BIGINT NOT NULL COMMENT '选项值ID(用于JSON)',
  54. value_name VARCHAR(64) NOT NULL COMMENT '选项值名称',
  55. is_default TINYINT DEFAULT 0 COMMENT '是否默认',
  56. is_normal TINYINT DEFAULT 1 COMMENT '是否正常值',
  57. required TINYINT DEFAULT 1 COMMENT '是否必填',
  58. is_multi TINYINT DEFAULT 0 COMMENT '是否多选',
  59. sort_order INT DEFAULT 0,
  60. is_base_price_attr TINYINT DEFAULT 0 COMMENT '是否用于选择基准价',
  61. create_time DATETIME DEFAULT CURRENT_TIMESTAMP,
  62. update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  63. KEY idx_tpl (base_template_id),
  64. KEY idx_attr (attr_key)
  65. ) COMMENT='step1 模板属性表';
  66. /* ================= 基础价格 ================= */
  67. CREATE TABLE machine_base_price (
  68. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  69. machine_id BIGINT,
  70. capacity VARCHAR(32),
  71. base_price DECIMAL(10,2),
  72. UNIQUE KEY uk_machine_capacity (machine_id, capacity)
  73. );
  74. /* ================= 扣减系数 ================= */
  75. CREATE TABLE price_option_factor (
  76. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  77. option_id BIGINT,
  78. factor DECIMAL(5,4) DEFAULT 1.0000,
  79. absolute_deduct DECIMAL(10,2) DEFAULT 0
  80. );
  81. /* ================= 调节系数 ================= */
  82. CREATE TABLE price_adjust_factor (
  83. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  84. level VARCHAR(32),
  85. ref_id BIGINT,
  86. factor DECIMAL(5,4) DEFAULT 1.0000
  87. );
  88. /* ================ 基础模板 ================= */
  89. CREATE TABLE base_estimate_template (
  90. id BIGINT PRIMARY KEY COMMENT '99181 / 99198 / 99197',
  91. name VARCHAR(64) NOT NULL,
  92. template_json JSON NOT NULL,
  93. template_version INT DEFAULT 1,
  94. remark VARCHAR(255),
  95. create_time DATETIME DEFAULT CURRENT_TIMESTAMP,
  96. update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
  97. );
  98. /* ================= 估价版本 ================= */
  99. CREATE TABLE estimate_version (
  100. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  101. machine_id BIGINT,
  102. version_no VARCHAR(32),
  103. content TEXT,
  104. create_time DATETIME DEFAULT CURRENT_TIMESTAMP
  105. );
  106. /* ================= 估价记录 ================= */
  107. CREATE TABLE estimate_record (
  108. id BIGINT AUTO_INCREMENT PRIMARY KEY,
  109. machine_id BIGINT,
  110. capacity VARCHAR(32),
  111. option_ids TEXT,
  112. final_price DECIMAL(10,2),
  113. version_no VARCHAR(32),
  114. create_time DATETIME DEFAULT CURRENT_TIMESTAMP
  115. );