-- 交易明细事实表 (dwd_trade_order_detail) -- 用于拉取有赞 trades.sold.get 等接口数据,基于订单明细粒度(SKU级别) CREATE TABLE `dwd_trade_order_detail` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '底层自增主键', `tid` VARCHAR(64) NOT NULL COMMENT '有赞主订单号 (tid)', `oid` VARCHAR(64) NOT NULL COMMENT '有赞子订单号/明细ID (oid)', `buyer_phone` VARCHAR(32) DEFAULT NULL COMMENT '买家手机号 (buyer_info.buyer_phone),基于安全组件可能脱敏', `yz_open_id` VARCHAR(64) DEFAULT NULL COMMENT '有赞用户开放ID (buyer_info.yz_open_id)', `fans_id` BIGINT DEFAULT NULL COMMENT '粉丝ID (buyer_info.fans_id)', `shop_org_id` VARCHAR(64) DEFAULT NULL COMMENT '店铺组织ID (shop_org_id)', `offline_id` BIGINT DEFAULT NULL COMMENT '网点/门店ID (node_kdt_id)', `item_id` BIGINT NOT NULL COMMENT '商品ID (item_id)', `sku_id` BIGINT NOT NULL COMMENT 'SKU ID (sku_id)', `outer_item_id` VARCHAR(128) DEFAULT NULL COMMENT '商家外部商品编码 (outer_item_id) - 核心映射字段', `outer_sku_id` VARCHAR(128) DEFAULT NULL COMMENT '商家外部SKU编码 (outer_sku_id)', `title` VARCHAR(255) DEFAULT NULL COMMENT '商品名称快照 (title)', `price` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '单商品原价 (price)', `num` INT NOT NULL DEFAULT 0 COMMENT '购买数量 (num)', `total_fee` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '该明细原价小计 (total_fee = price * num)', `discount_price` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '单商品折扣后价格 (discount_price)', `payment` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '该明细实际支付摊销金额 (payment) - 计算销售额核心', `status` VARCHAR(32) NOT NULL COMMENT '当前主订单状态 (status: WAIT_SELLER_SEND_GOODS 等)', `refund_state` INT DEFAULT 0 COMMENT '退款状态 (refund_state: 0正常, 其他视情况)', `source_platform` VARCHAR(32) DEFAULT NULL COMMENT '订单来源平台 (source_info.source.platform: weixin/other)', `is_retail_order` TINYINT(1) DEFAULT 0 COMMENT '是否零售门店订单 (order_info.is_retail_order)', `order_type` INT DEFAULT 0 COMMENT '订单类型 (order_info.type: 0-普通 10-零售门店)', `pay_time` DATETIME DEFAULT NULL COMMENT '支付时间 (pay_time) - 业务时间戳', `created_time` DATETIME DEFAULT NULL COMMENT '订单创建时间 (created)', `update_time` DATETIME DEFAULT NULL COMMENT '订单最后更新时间 (update_time)', `success_time` DATETIME DEFAULT NULL COMMENT '订单完成时间 (success_time)', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台数据更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_oid` (`oid`), KEY `idx_tid` (`tid`), KEY `idx_pay_time` (`pay_time`), KEY `idx_update_time` (`update_time`), KEY `idx_buyer` (`buyer_phone`, `yz_open_id`), KEY `idx_item_sku` (`item_id`, `sku_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='交易明细事实表 (T+1有赞同步)'; -- 客户维度宽表 (dim_customer_info) -- 用于融合有赞买家、微信粉丝、线下POS留资,构建 OneID 视图及基础标签 CREATE TABLE `dim_customer_info` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '中台内部统一客户ID (OneID)', `mobile` VARCHAR(32) DEFAULT NULL COMMENT '手机号(首选关联枢纽,微信粉丝场景可能缺失)', `yz_open_id` VARCHAR(64) DEFAULT NULL COMMENT '有赞生态统一用户ID(备选主键)', `wx_union_id` VARCHAR(64) DEFAULT NULL COMMENT '微信生态UnionID', `wx_open_id` VARCHAR(64) DEFAULT NULL COMMENT '微信公众号/小程序OpenID', `nickname` VARCHAR(128) DEFAULT NULL COMMENT '客户昵称快照 (fans_nickname)', `name` VARCHAR(64) DEFAULT NULL COMMENT '客户真实姓名(若有)', `gender` TINYINT DEFAULT 0 COMMENT '性别: 0-未知, 1-男, 2-女', `birthday` DATE DEFAULT NULL COMMENT '生日', `register_time` DATETIME DEFAULT NULL COMMENT '首次注册/留资时间', `register_channel` VARCHAR(32) DEFAULT NULL COMMENT '注册渠道 (有赞、线下门店、微信等)', `member_level_id` BIGINT DEFAULT NULL COMMENT '当前会员等级ID', `member_level_name` VARCHAR(64) DEFAULT NULL COMMENT '当前会员等级名称', `first_pay_time` DATETIME DEFAULT NULL COMMENT '首单支付时间', `last_pay_time` DATETIME DEFAULT NULL COMMENT '最近一次支付时间(用于RFM-R计算)', `total_pay_amount` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '历史累计实付金额(用于RFM-M计算)', `total_pay_count` INT DEFAULT 0 COMMENT '历史累计支付订单数(用于RFM-F计算)', `customer_tags` JSON DEFAULT NULL COMMENT '客户身上的业务标签集合 (JSON格式存储,如 ["高潜", "流失预警"])', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台数据更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_yz_open_id` (`yz_open_id`), UNIQUE KEY `uk_mobile` (`mobile`), -- 可空唯一: MySQL 允许多个 NULL, 有手机号则保证不重复 KEY `idx_wx_union_id` (`wx_union_id`), KEY `idx_last_pay_time` (`last_pay_time`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='统一客户维度宽表 (OneID及基础RFM视角)'; -- ========================================== -- 新增:商品维表、门店维表、库存流水、退货退款明细 -- ========================================== -- 商品与SKU维表 (dim_item_sku) -- 记录有赞商品的快照及外部映射,用以统一冷链和热食的销售分析 CREATE TABLE `dim_item_sku` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `item_id` BIGINT NOT NULL COMMENT '有赞商品ID (item_id)', `sku_id` BIGINT NOT NULL COMMENT '有赞SKU ID (sku_id)', `outer_item_id` VARCHAR(128) DEFAULT NULL COMMENT '商家外部商品编码 (关联核心)', `outer_sku_id` VARCHAR(128) DEFAULT NULL COMMENT '商家外部SKU编码', `barcode` VARCHAR(128) DEFAULT NULL COMMENT '商品条码', `title` VARCHAR(255) NOT NULL COMMENT '商品/SKU名称', `alias` VARCHAR(128) DEFAULT NULL COMMENT '商品别名/短链接标识', `category_id` BIGINT DEFAULT NULL COMMENT '叶子类目ID', `category_name` VARCHAR(128) DEFAULT NULL COMMENT '叶子类目名称', `group_ids` VARCHAR(255) DEFAULT NULL COMMENT '商品分组ID列表 (逗号分隔)', `price` BIGINT DEFAULT 0 COMMENT '当前售卖价(单位:分)', `cost_price` BIGINT DEFAULT 0 COMMENT '成本价(单位:分,若有)', `is_listing` TINYINT(1) DEFAULT 1 COMMENT '是否上架: 1-上架, 0-下架', `created_time` DATETIME DEFAULT NULL COMMENT '商品在有赞的创建时间', `update_time` DATETIME DEFAULT NULL COMMENT '商品最近更新时间', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台数据更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_item_sku` (`item_id`, `sku_id`), KEY `idx_outer_item_id` (`outer_item_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品与SKU维度表'; -- 门店与网点维表 (dim_offline_store) CREATE TABLE `dim_offline_store` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `offline_id` BIGINT NOT NULL COMMENT '有赞网点/门店ID (offline_id / node_kdt_id)', `shop_org_id` VARCHAR(64) DEFAULT NULL COMMENT '组织店铺ID', `name` VARCHAR(128) NOT NULL COMMENT '门店名称', `type` VARCHAR(32) DEFAULT NULL COMMENT '节点类型: STORE-门店, WAREHOUSE-仓库', `province` VARCHAR(64) DEFAULT NULL COMMENT '省份', `city` VARCHAR(64) DEFAULT NULL COMMENT '城市', `district` VARCHAR(64) DEFAULT NULL COMMENT '区县', `address` VARCHAR(255) DEFAULT NULL COMMENT '详细地址', `status` TINYINT(1) DEFAULT 1 COMMENT '营业状态: 1-营业, 0-关店', `warehouse_code` VARCHAR(64) DEFAULT NULL COMMENT '仓库编码 (库存API必需, warehouse.query获取)', `stock_mode` INT DEFAULT NULL COMMENT '库存模式: 1-独立销售库存, 2-共享总部, 3-共享门店仓, 4-进出存单据管理', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台数据更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_offline_id` (`offline_id`), KEY `idx_city` (`city`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='门店与网点维度表'; -- 售后与退款明细事实表 (dwd_trade_refund_detail) -- 用于计算交易净额 (GMV = 支付额 - 退款额) CREATE TABLE `dwd_trade_refund_detail` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `refund_id` VARCHAR(64) NOT NULL COMMENT '退款单号 (refund_id)', `tid` VARCHAR(64) NOT NULL COMMENT '关联的有赞主订单号 (tid)', `oid` VARCHAR(64) DEFAULT NULL COMMENT '关联的子订单明细ID (oid, 若仅退款则为空)', `offline_id` BIGINT DEFAULT NULL COMMENT '发起退款的门店ID (处理多网点)', `refund_type` INT DEFAULT 1 COMMENT '退款类型: 1-仅退款, 2-退货退款', `refund_fee` DECIMAL(12, 2) NOT NULL DEFAULT 0.00 COMMENT '实际退款金额', `reason` VARCHAR(255) DEFAULT NULL COMMENT '退款原因 (整数编码: 54-未发货, 11-质量问题等)', `status` VARCHAR(32) NOT NULL COMMENT '退款状态 (SUCCESS/CLOSED/WAIT_SELLER_AGREE等)', `created_time` DATETIME DEFAULT NULL COMMENT '退款申请时间', `success_time` DATETIME DEFAULT NULL COMMENT '退款成功时间', `modified_time` DATETIME DEFAULT NULL COMMENT '退款最后修改时间', `refund_demand` INT DEFAULT NULL COMMENT '退款诉求: 1-仅退款, 2-退货退款, 3-换货', `refund_phase` INT DEFAULT NULL COMMENT '退款阶段: 1-售中, 2-售后', `yz_open_id` VARCHAR(64) DEFAULT NULL COMMENT '买家有赞用户ID (yz_open_id)', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台数据更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_refund_id` (`refund_id`), KEY `idx_tid` (`tid`), KEY `idx_success_time` (`success_time`), KEY `idx_yz_open_id` (`yz_open_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='售后与退款明细表'; -- 每日库存快照表 (dim_inventory_snapshot) -- 记录每日各仓库/门店的SKU库存余量,用于库存周转分析和缺货预警 CREATE TABLE `dim_inventory_snapshot` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `warehouse_code` VARCHAR(64) NOT NULL COMMENT '仓库编码 (warehouse.query获取)', `sku_code` VARCHAR(128) NOT NULL COMMENT 'SKU编码 (outer_sku_id)', `stock_num` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '实物库存数量', `freeze_num` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '实物库存占用 (被订单锁定)', `available_num` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '可用库存 (stock_num - freeze_num)', `snapshot_date` DATE NOT NULL COMMENT '快照日期', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台同步时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_snapshot` (`warehouse_code`, `sku_code`, `snapshot_date`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='每日库存快照表'; -- 进销存库存流水事实表 (dwd_inventory_flow_di) -- 记录每日出入库流水,辅助动销分析与损耗监控 CREATE TABLE `dwd_inventory_flow_di` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `biz_no` VARCHAR(64) NOT NULL COMMENT '业务单据号 (如盘点单号, 采购单号)', `biz_type` VARCHAR(32) NOT NULL COMMENT '单据类型: PURCHASE-采购, ALLOCATE-调拨, CHECK-盘点, ADJUST-调整', `offline_id` BIGINT NOT NULL COMMENT '发生动作的门店/仓库ID', `item_id` BIGINT NOT NULL COMMENT '商品ID', `sku_id` BIGINT NOT NULL COMMENT 'SKU ID', `change_quantity` INT NOT NULL COMMENT '库存变动量 (正数为入, 负数为出)', `after_quantity` INT DEFAULT NULL COMMENT '变动后该SKU的总可用库存', `reason` VARCHAR(255) DEFAULT NULL COMMENT '变动原因 (如报损说明, 盘点原因)', `occur_time` DATETIME NOT NULL COMMENT '流水发生时间', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台同步时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_biz_flow` (`biz_no`, `item_id`, `sku_id`, `offline_id`, `biz_type`), KEY `idx_offline_sku` (`offline_id`, `sku_id`), KEY `idx_occur_time` (`occur_time`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='库存变动流水记录表'; -- ========================================== -- 新增:优惠券/营销活动事实表 -- ========================================== -- 优惠券流水事实表 (dwd_coupon_flow) -- 记录优惠券的发放与核销,用于活动ROI分析 CREATE TABLE `dwd_coupon_flow` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `coupon_group_id` BIGINT NOT NULL COMMENT '优惠券活动/券组ID (coupon_group_id)', `coupon_id` VARCHAR(64) NOT NULL COMMENT '优惠券实例ID / 券码 (verify_code)', `yz_open_id` VARCHAR(64) DEFAULT NULL COMMENT '领券/用券用户 (yz_open_id)', `mobile` VARCHAR(32) DEFAULT NULL COMMENT '用户手机号', `coupon_type` VARCHAR(32) DEFAULT NULL COMMENT '券类型: CASH-满减, DISCOUNT-折扣, EXCHANGE-兑换', `coupon_name` VARCHAR(128) DEFAULT NULL COMMENT '券名称', `denomination` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '面额/减免金额', `condition_amount` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '使用门槛金额 (满X元可用)', `send_time` DATETIME DEFAULT NULL COMMENT '发放时间', `use_time` DATETIME DEFAULT NULL COMMENT '核销/使用时间', `expire_time` DATETIME DEFAULT NULL COMMENT '过期时间', `status` VARCHAR(32) NOT NULL COMMENT '券状态: SENT-已发, USED-已核销, EXPIRED-已过期', `use_tid` VARCHAR(64) DEFAULT NULL COMMENT '核销时关联的订单号 (tid)', `use_offline_id` BIGINT DEFAULT NULL COMMENT '核销门店ID (offline_id)', `activity_id` BIGINT DEFAULT NULL COMMENT '关联营销活动ID (activity_id)', `activity_type` VARCHAR(32) DEFAULT NULL COMMENT '活动类型', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '中台同步时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_coupon_id` (`coupon_id`), KEY `idx_coupon_group` (`coupon_group_id`), KEY `idx_yz_open_id` (`yz_open_id`), KEY `idx_use_time` (`use_time`), KEY `idx_use_tid` (`use_tid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='优惠券流水事实表 (发放与核销)'; -- ========================================== -- Phase 4: 商品与会员洞察 (ADM数据市集层) -- ========================================== -- 1. 客户 RFM 与评分模型表 CREATE TABLE IF NOT EXISTS `adm_customer_rfm` ( `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '自增主键', `yz_open_id` VARCHAR(64) NOT NULL COMMENT '有赞open_id', `mobile` VARCHAR(32) DEFAULT NULL COMMENT '客户手机号', `last_trade_time` DATETIME DEFAULT NULL COMMENT '最近一次消费时间 (Recency)', `trade_count_90d` INT DEFAULT 0 COMMENT '近90天消费频次 (Frequency)', `trade_amount_90d` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '近90天消费金额 (Monetary)', `r_score` INT DEFAULT 0 COMMENT 'R得分(1-5级)', `f_score` INT DEFAULT 0 COMMENT 'F得分(1-5级)', `m_score` INT DEFAULT 0 COMMENT 'M得分(1-5级)', `rfm_group` VARCHAR(32) DEFAULT NULL COMMENT '客群分层(例如: 重要价值客户/沉睡客户等)', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '同步更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_yz_open_id` (`yz_open_id`), KEY `idx_rfm_group` (`rfm_group`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='会员RFM洞察表'; -- 2. 客户标签表 (人群特征画像) CREATE TABLE IF NOT EXISTS `adm_customer_tags` ( `id` BIGINT NOT NULL AUTO_INCREMENT, `yz_open_id` VARCHAR(64) NOT NULL, `tag_name` VARCHAR(64) NOT NULL COMMENT '标签名称(如: 工作日外带客, 高客单囤货客)', `tag_value` VARCHAR(128) DEFAULT NULL COMMENT '标签值或权重', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE KEY `uk_customer_tag` (`yz_open_id`, `tag_name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='客户画像标签表'; -- 3. 商品销售趋势表 (日维统计, 按 outer_item_id 聚合) CREATE TABLE IF NOT EXISTS `adm_item_sales_trend` ( `id` BIGINT NOT NULL AUTO_INCREMENT, `stat_date` DATE NOT NULL COMMENT '统计归属日期', `item_id` BIGINT NOT NULL COMMENT '商品ID (代表性)', `sku_id` BIGINT NOT NULL DEFAULT 0 COMMENT '规格ID', `outer_item_id` VARCHAR(64) DEFAULT NULL COMMENT '商家统一商品编码', `item_name` VARCHAR(128) DEFAULT NULL COMMENT '商品名称', `sales_qty` INT DEFAULT 0 COMMENT '当日销量(件数)', `sales_amount` DECIMAL(12, 2) DEFAULT 0.00 COMMENT '当日销售额', `order_count` INT DEFAULT 0 COMMENT '当日包含该商品的订单数', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE KEY `uk_trend_date` (`stat_date`, `outer_item_id`), KEY `idx_item` (`item_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品销售趋势表'; -- 4. 商品关联分析表 (购物篮挖掘, 按 outer_item_id 聚合) CREATE TABLE IF NOT EXISTS `adm_item_basket` ( `id` BIGINT NOT NULL AUTO_INCREMENT, `item_id_a` BIGINT NOT NULL COMMENT '商品A', `outer_item_id_a` VARCHAR(64) DEFAULT NULL COMMENT '商品A商家编码', `item_name_a` VARCHAR(128) DEFAULT NULL COMMENT '商品A名称', `item_id_b` BIGINT NOT NULL COMMENT '商品B', `outer_item_id_b` VARCHAR(64) DEFAULT NULL COMMENT '商品B商家编码', `item_name_b` VARCHAR(128) DEFAULT NULL COMMENT '商品B名称', `pair_order_count` INT DEFAULT 0 COMMENT 'A和B共同出现的订单数', `item_a_order_count` INT DEFAULT 0 COMMENT 'A独立出现的包含订单总数', `confidence` DECIMAL(5, 4) DEFAULT 0.0000 COMMENT '置信度 (A->B的概率)', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE KEY `uk_item_pair` (`outer_item_id_a`, `outer_item_id_b`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品购物篮关联分析表'; -- 5. 商品复购分析表 (按 outer_item_id 聚合) CREATE TABLE IF NOT EXISTS `adm_item_repurchase` ( `id` BIGINT NOT NULL AUTO_INCREMENT, `stat_date` DATE NOT NULL COMMENT '统计归属日期', `item_id` BIGINT NOT NULL COMMENT '商品ID (代表性)', `sku_id` BIGINT NOT NULL DEFAULT 0, `outer_item_id` VARCHAR(64) DEFAULT NULL COMMENT '商家统一商品编码', `item_name` VARCHAR(128) DEFAULT NULL COMMENT '商品名称', `purchaser_count_30d` INT DEFAULT 0 COMMENT '过去30天购买总人数', `repurchaser_count_30d` INT DEFAULT 0 COMMENT '过去30天产生二次复购的人数', `repurchase_rate_30d` DECIMAL(5, 4) DEFAULT 0.0000 COMMENT '30天复购率 (二次人数/总人数)', `matrix_tag` VARCHAR(32) DEFAULT NULL COMMENT '波士顿矩阵打标分类 (如: 核心引流款, 需淘汰等)', `etl_update_time` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`), UNIQUE KEY `uk_repurchase_date` (`stat_date`, `outer_item_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品复购率分析表';