280 lines
15 KiB
Markdown
280 lines
15 KiB
Markdown
---
|
||
inclusion: fileMatch
|
||
fileMatchPattern: "**/tasks/**,**/loaders/**,**/scd/**,**/dws/**,**/dwd/**,**/quality/**,**/business-rules/**,**/schemas/**,**/routers/**,**/financial*,**/settlement*,**/consume*,**/accounting*,**/salary*,**/assistant*,**/member*,**/index*,**/winback*,**/newconv*,**/relation_index*,**/spending*,**/stock*,**/finance_*,**/income_*,**/discount_*,**/order_contribution*,**/cfg_*,**/orchestration/**,**/config/**"
|
||
name: dws-doc-authority
|
||
description: DWS 层权威规范。涉及 ETL 任务/财务/结算/消费/助教/会员/指数/统计/配置相关文件时自动加载。
|
||
---
|
||
|
||
# DWS 层权威规范(强制优先参考)
|
||
|
||
DWS(Data Warehouse Summary)层从 DWD 明细层按业务维度聚合计算,输出汇总统计表,服务于助教业绩、会员分析、财务统计、指数算法等业务场景。
|
||
|
||
> DWD-DOC(`docs/reports/DWD-DOC/`)中的强制规则在 DWS 层同样生效,本文档不重复列出。两者冲突时以 DWD-DOC 为准。
|
||
|
||
## 一、任务体系(19 个已注册任务)
|
||
|
||
### 1.1 助教业绩域(6 个)
|
||
|
||
| 任务代码 | 目标表 | 粒度 | 核心指标 |
|
||
|----------|--------|------|----------|
|
||
| `DWS_ASSISTANT_DAILY` | `dws_assistant_daily_detail` | 日期+助教 | 服务次数/时长/金额、去重客户数、废除统计、惩罚检测 |
|
||
| `DWS_ASSISTANT_MONTHLY` | `dws_assistant_monthly_summary` | 月份+助教 | 月度累计、有效业绩、档位匹配、排名(考虑并列) |
|
||
| `DWS_ASSISTANT_CUSTOMER` | `dws_assistant_customer_stats` | 日期+助教+会员 | 全量累计、6 个滚动窗口(7/10/15/30/60/90 天)、活跃度 |
|
||
| `DWS_ASSISTANT_SALARY` | `dws_assistant_salary_calc` | 月份+助教 | 课时收入、奖金明细、应发工资、假期 |
|
||
| `DWS_ASSISTANT_FINANCE` | `dws_assistant_finance_analysis` | 日期+助教 | 日度收入、日均成本、毛利润、毛利率 |
|
||
| `DWS_ASSISTANT_ORDER_CONTRIBUTION` | `dws_assistant_order_contribution` | 日期+助教 | 订单总流水、净流水、时效贡献、时效净贡献 |
|
||
|
||
### 1.2 会员分析域(2 个)
|
||
|
||
| 任务代码 | 目标表 | 粒度 | 核心指标 |
|
||
|----------|--------|------|----------|
|
||
| `DWS_MEMBER_CONSUMPTION` | `dws_member_consumption_summary` | 日期+会员 | 全量累计消费、6 个滚动窗口、卡余额、活跃度、客户分层 |
|
||
| `DWS_MEMBER_VISIT` | `dws_member_visit_detail` | 日期+会员+结账单 | 消费金额拆分、支付方式拆分、台桌时长、助教服务明细(JSON) |
|
||
|
||
### 1.3 财务统计域(4 个)
|
||
|
||
| 任务代码 | 目标表 | 粒度 | 核心指标 |
|
||
|----------|--------|------|----------|
|
||
| `DWS_FINANCE_DAILY` | `dws_finance_daily_summary` | 日期 | 发生额、优惠合计、确认收入、现金流入/流出/净变动、卡消费、充值统计 |
|
||
| `DWS_FINANCE_RECHARGE` | `dws_finance_recharge_summary` | 日期 | 充值笔数/总额、首充/续充拆分、去重会员数、全店卡余额快照 |
|
||
| `DWS_FINANCE_INCOME_STRUCTURE` | `dws_finance_income_structure` | 日期+收入类型 | 按收入类型(台费/商品/助教基础课/附加课)和区域分析 |
|
||
| `DWS_FINANCE_DISCOUNT_DETAIL` | `dws_finance_discount_detail` | 日期+折扣类型 | 折扣类型拆分(GROUPBUY/VIP/ROUNDING/GIFT_CARD_*/BIG_CUSTOMER/OTHER) |
|
||
|
||
### 1.4 库存汇总域(3 个)
|
||
|
||
| 任务代码 | 目标表 | 粒度 | 更新策略 |
|
||
|----------|--------|------|----------|
|
||
| `DWS_GOODS_STOCK_DAILY` | `dws_goods_stock_daily_summary` | 日期+商品 | upsert |
|
||
| `DWS_GOODS_STOCK_WEEKLY` | `dws_goods_stock_weekly_summary` | ISO 周+商品 | upsert |
|
||
| `DWS_GOODS_STOCK_MONTHLY` | `dws_goods_stock_monthly_summary` | 月份+商品 | upsert |
|
||
|
||
### 1.5 运维任务(2 个)
|
||
|
||
| 任务代码 | 说明 |
|
||
|----------|------|
|
||
| `DWS_BUILD_ORDER_SUMMARY` | 构建订单汇总中间表 `dws_order_summary` |
|
||
| `DWS_MAINTENANCE` | 统一维护:物化视图刷新 + 历史数据清理 |
|
||
|
||
|
||
## 二、强制规则(所有 session 生效)
|
||
|
||
### 2.1 幂等更新策略
|
||
1. **汇总表默认 delete-before-insert**:按日期范围 + `site_id` 先删后插,保证幂等
|
||
2. **库存表使用 upsert**:`ON CONFLICT DO UPDATE`,因库存快照需保留最新值
|
||
3. **禁止 TRUNCATE**:DWS 表数据量大,TRUNCATE 会导致全表锁定
|
||
|
||
### 2.2 课程类型与定价
|
||
4. **课程类型通过 `cfg_skill_type` 映射**:`skill_id` → `course_type_code`(BASE/BONUS/ROOM),禁止硬编码 skill_id 判断课程类型
|
||
5. **定价通过 `cfg_assistant_level_price` 取值**:按 SCD2 生效期 as-of join,禁止硬编码价格
|
||
6. **包厢课统一价格**:`dws.salary.room_course_price = 138`(元/小时),从配置读取
|
||
|
||
### 2.3 绩效档位与工资
|
||
7. **绩效档位通过 `cfg_performance_tier` 取值**:按有效业绩小时数匹配 `[min_hours, max_hours)` 区间
|
||
8. **新入职折算规则**:入职日期在当月 1 日后视为新入职,按日均业绩 × 30 定档;入职日期 > 25 日最高定档至 T2
|
||
9. **奖金规则通过 `cfg_bonus_rules` 取值**:SPRINT 类型不累计取最高档,TOP_RANK 类型按排名发放(第 1 名 1000 元、第 2 名 600 元、第 3 名 400 元)
|
||
10. **排名计算考虑并列**:使用 `calculate_rank_with_ties()`,相同业绩小时数并列同名次
|
||
|
||
### 2.4 会员与散客
|
||
11. **散客判断**:`member_id ≤ 0` 为散客,不计入会员统计(但计入助教业绩)
|
||
12. **客户分层规则**:高价值(90 天 ≥ 3 次且 ≥ 1000 元)→ 中等(30 天内有消费)→ 低活跃(90 天内有但 30 天内无)→ 流失
|
||
13. **会员信息一律通过 ID 关联维度表**:结算单上所有会员冗余字段均不可靠(DQ-6/DQ-7),通过 `member_id` LEFT JOIN `dwd.dim_member`(`scd2_is_current=1`)
|
||
|
||
### 2.5 时间窗口与调度
|
||
14. **滚动窗口标准集**:7/10/15/30/60/90 天,使用 `calculate_rolling_stats()` 统一计算
|
||
15. **月度任务宽限期**:月初前 `dws.monthly.prev_month_grace_days`(默认 5)天可处理上月数据
|
||
16. **工资计算周期**:月初前 `dws.salary.run_days`(默认 5)天运行,超期需 `dws.salary.allow_out_of_cycle = true`
|
||
|
||
### 2.6 SCD2 维度取值
|
||
17. **助教等级 as-of 取值**:工资计算按月份生效期取历史版本,日度统计按 `stat_date` 取当日版本
|
||
18. **会员卡余额 as-of 取值**:通过 `get_member_card_balance_asof()` 按日期取快照
|
||
|
||
### 2.7 台桌分类
|
||
19. **`cfg_area_category` 仅精确匹配 + 兜底**:2026-03-07 改版后无 LIKE 匹配,分类为 BILLIARD/SNOOKER/OTHER,`BILLIARD_VIP` 已废弃
|
||
|
||
## 三、指数算法体系
|
||
|
||
### 3.1 总览
|
||
|
||
| 指数 | 全称 | 输出表 | 作用 |
|
||
|------|------|--------|------|
|
||
| WBI | Winback Index | `dws_member_winback_index` | 老客挽回优先级 |
|
||
| NCI | Newconv Index | `dws_member_newconv_index` | 新客转化优先级 |
|
||
| RS | Relation Index | `dws_member_assistant_relation_index` | 助教-会员关系强度 |
|
||
| OS | Ownership Index | — | 所有权指数 |
|
||
| MS | Maintenance Score | — | 维护分 |
|
||
| ML | Manual Ledger | `dws_ml_manual_order_alloc` | 人工台账(唯一真源) |
|
||
| SPI | Spending Power Index | `dws_member_spending_power_index` | 消费力指数 |
|
||
|
||
### 3.2 WBI(老客挽回指数)强制规则
|
||
20. **分项得分**:Overdue(超期分,加权经验 CDF)+ Drop(降频分,近 14 天差值)+ Recharge(充值压力,衰减分)+ Value(价值分,对数压缩)
|
||
21. **Raw Score 公式**:`WBI_raw = w_over × overdue + w_drop × drop + w_re × recharge + w_value × value`
|
||
22. **近访抑制(Recency Suppression)**:距今 < 14 天 suppression = 0(Hard floor);14-17 天 Sigmoid 衰减
|
||
23. **分流规则**:STOP(距今 ≥ 60 天,高余额例外可选)→ NEW(到店 ≤ 2 次或首访 ≤ 30 天或充值未回访)→ OLD(其他)
|
||
|
||
### 3.3 NCI(新客转化指数)强制规则
|
||
24. **分项得分**:Welcome(欢迎分,首访/单访 3 天内触发)+ Need(转化紧迫度)+ Salvage(可救度,30-60 天线性衰减)+ Recharge/Value(同 WBI)
|
||
25. **活跃抑制**:新客近 14 天来店 ≥ 2 次且最近活跃,用 0.2 系数抑制转化召回分
|
||
|
||
### 3.4 指数参数配置
|
||
26. **参数通过 `cfg_index_parameters` 加载**:按 `index_type` 分组,支持 EWMA 平滑,禁止硬编码权重/阈值
|
||
|
||
|
||
## 四、配置表体系
|
||
|
||
### 4.1 绩效档位(`dws.cfg_performance_tier`)
|
||
|
||
| 档位 | 小时区间 | 抽成(元/小时) | 打赏抽成 | 假期 |
|
||
|------|----------|-----------------|----------|------|
|
||
| T0(0 档) | 0-120 | 28 | 50% | 3 天 |
|
||
| T1(1 档) | 120-150 | 18 | 40% | 4 天 |
|
||
| T2(2 档) | 150-180 | 13 | 35% | 5 天 |
|
||
| T3(3 档) | 180-210 | 10 | 30% | 6 天 |
|
||
| T4(4 档) | 210+ | 8 | 25% | 自由假期 |
|
||
|
||
> 以上为 2026-03-01 起生效版本,历史版本通过 `effective_from/effective_to` SCD2 管理。
|
||
|
||
### 4.2 助教等级定价(`dws.cfg_assistant_level_price`)
|
||
|
||
| 等级 | 基础课(元/小时) | 附加课(元/小时) |
|
||
|------|-------------------|-------------------|
|
||
| 8(助教管理) | 98 | 190 |
|
||
| 10(初级) | 98 | 190 |
|
||
| 20(中级) | 108 | 190 |
|
||
| 30(高级) | 118 | 190 |
|
||
| 40(星级) | 138 | 190 |
|
||
|
||
### 4.3 奖金规则(`dws.cfg_bonus_rules`)
|
||
|
||
| 规则类型 | 生效期 | 说明 |
|
||
|----------|--------|------|
|
||
| SPRINT(冲刺奖金) | ≤ 2026-02-28 | 不累计,取最高档 |
|
||
| TOP_RANK(排名奖金) | ≥ 2026-03-01 | 第 1 名 1000 元、第 2 名 600 元、第 3 名 400 元 |
|
||
|
||
### 4.4 技能→课程类型映射(`dws.cfg_skill_type`)
|
||
|
||
| 课程类型代码 | 名称 | 定价规则 |
|
||
|-------------|------|----------|
|
||
| BASE | 基础课(陪打/PD) | 按等级定价 98-138 元/小时 |
|
||
| BONUS | 附加课(超休/CX) | 固定 190 元/小时 |
|
||
| ROOM | 包厢课 | 统一 138 元/小时(`dws.salary.room_course_price`) |
|
||
|
||
### 4.5 台桌分类(`dws.cfg_area_category`)
|
||
|
||
| 分类代码 | 说明 | 备注 |
|
||
|----------|------|------|
|
||
| BILLIARD | 台球(含原 V1-V4) | 2026-03-07 改版 |
|
||
| SNOOKER | 斯诺克(含原 V5) | 2026-03-07 改版 |
|
||
| OTHER | 兜底 | 未匹配时归入 |
|
||
|
||
> `BILLIARD_VIP` 已废弃(2026-03-07),禁止引用。
|
||
|
||
### 4.6 指数参数(`dws.cfg_index_parameters`)
|
||
|
||
按 `index_type`(WBI/NCI/RS/OS/MS/ML/SPI)分组加载,支持 EWMA 平滑。所有权重和阈值从此表读取,禁止硬编码。
|
||
|
||
## 五、BaseDwsTask 公共机制
|
||
|
||
### 5.1 时间分层(TimeLayer)
|
||
|
||
| 枚举值 | 范围 | 用途 |
|
||
|--------|------|------|
|
||
| LAST_2_DAYS | 近 2 天 | 日度增量 |
|
||
| LAST_1_MONTH | 近 30 天 | 月度汇总 |
|
||
| LAST_3_MONTHS | 近 90 天 | 季度分析 |
|
||
| LAST_6_MONTHS | 近 6 个月(不含本月) | 半年趋势 |
|
||
| ALL | 从 2000-01-01 起 | 全量重算 |
|
||
|
||
### 5.2 配置缓存(ConfigCache)
|
||
- 类级别共享,TTL 5 分钟
|
||
- 包含:绩效档位、等级定价、奖金规则、区域分类、技能类型
|
||
- 支持 SCD2 生效期过滤
|
||
|
||
### 5.3 数据读写方法
|
||
- `iter_dwd_rows()`:分批迭代 DWD 数据(默认 1000 行/批)
|
||
- `query_dwd()`:直接执行任意 SQL
|
||
- `delete_existing_data()`:按日期范围 + site_id 删除
|
||
- `bulk_insert()`:批量插入
|
||
- `upsert()`:ON CONFLICT DO UPDATE
|
||
|
||
### 5.4 辅助计算
|
||
- `calculate_rolling_stats()`:滚动窗口统计
|
||
- `calculate_rank_with_ties()`:并列排名
|
||
- `is_new_hire_in_month()`:新入职判断
|
||
- `is_guest()`:散客判断(member_id ≤ 0)
|
||
- `safe_decimal()` / `safe_int()`:安全类型转换
|
||
- `seconds_to_hours()` / `hours_to_seconds()`:时间单位转换
|
||
- `get_assistant_level_asof()`:SCD2 助教等级
|
||
- `get_member_card_balance_asof()`:SCD2 会员卡余额
|
||
|
||
## 六、字段命名规范
|
||
|
||
### 6.1 金额字段
|
||
- 统一 `NUMERIC(12,2)`,货币单位 CNY
|
||
- 储值卡:DWS 层使用 `balance_pay`(总额)、`recharge_card_pay`(现金充值卡)、`gift_card_pay`(赠送卡)
|
||
- 财务日报:使用 `recharge_card_consume`
|
||
- 助教费用:`assistant_pd_money`(陪打)、`assistant_cx_money`(超休),禁止使用 `service_fee`
|
||
|
||
### 6.2 时间字段
|
||
- `stat_date`:统计日期(DATE)
|
||
- `stat_month`:统计月份(CHAR(7),格式 YYYY-MM)
|
||
- `created_at` / `updated_at`:TIMESTAMPTZ
|
||
|
||
### 6.3 标识字段
|
||
- `site_id`:门店 ID(多门店隔离,RLS)
|
||
- `tenant_id`:租户 ID
|
||
- `member_id`:会员 ID(≤ 0 为散客)
|
||
- `assistant_id`:助教 ID
|
||
|
||
## 七、调度与 Flow 类型
|
||
|
||
| Flow 类型 | 包含阶段 | 说明 |
|
||
|-----------|----------|------|
|
||
| `dwd_dws` | 仅 DWS 汇总 | 日常增量 |
|
||
| `dwd_dws_index` | DWS 汇总 + 指数计算 | 含指数更新 |
|
||
| `api_full` | ODS → DWD → DWS → INDEX | 全流程 |
|
||
|
||
处理模式:`increment_only`(默认)、`verify_only`(仅校验修复)、`increment_verify`(先增量后校验)
|
||
|
||
## 八、DWS 层完整表清单
|
||
|
||
### 汇总表
|
||
`dws_assistant_daily_detail`、`dws_assistant_monthly_summary`、`dws_assistant_customer_stats`、`dws_assistant_salary_calc`、`dws_assistant_finance_analysis`、`dws_assistant_order_contribution`、`dws_member_consumption_summary`、`dws_member_visit_detail`、`dws_finance_daily_summary`、`dws_finance_recharge_summary`、`dws_finance_income_structure`、`dws_finance_discount_detail`、`dws_goods_stock_daily_summary`、`dws_goods_stock_weekly_summary`、`dws_goods_stock_monthly_summary`、`dws_order_summary`
|
||
|
||
### 指数表
|
||
`dws_member_winback_index`、`dws_member_newconv_index`、`dws_member_recall_index`、`dws_member_assistant_relation_index`、`dws_member_assistant_intimacy`、`dws_member_spending_power_index`、`dws_index_percentile_history`
|
||
|
||
### 其他表
|
||
`dws_platform_settlement`、`dws_ml_manual_order_source`、`dws_ml_manual_order_alloc`、`dws_assistant_recharge_commission`、`dws_assistant_project_tag`、`dws_member_project_tag`
|
||
|
||
### 视图
|
||
`v_member_recall_priority`
|
||
|
||
### 配置表
|
||
`cfg_performance_tier`、`cfg_assistant_level_price`、`cfg_bonus_rules`、`cfg_skill_type`、`cfg_area_category`、`cfg_index_parameters`
|
||
|
||
## 九、废弃对象(禁止引用)
|
||
|
||
| 对象 | 删除日期 | 替代方案 |
|
||
|------|----------|----------|
|
||
| `BILLIARD_VIP` 分类代码 | 2026-03-07 | V1-V4 归入 BILLIARD,V5 归入 SNOOKER |
|
||
| `dwd_assistant_trash_event` | 2026-02-22 | `dwd_assistant_service_log_ex.is_trash` |
|
||
| `RecallIndexTask` / `IntimacyIndexTask` | 2026-02-13 | WBI + NCI + RelationIndexTask |
|
||
| SPRINT 奖金规则 | 2026-02-28 止 | TOP_RANK 排名奖金(2026-03-01 起) |
|
||
|
||
## 十、关键文档索引
|
||
|
||
| 文档 | 路径 |
|
||
|------|------|
|
||
| DWS 任务详解 | `apps/etl/connectors/feiqiu/docs/etl_tasks/dws_tasks.md` |
|
||
| DWS 指标定义 | `apps/etl/connectors/feiqiu/docs/business-rules/dws_metrics.md` |
|
||
| 指数算法说明 | `apps/etl/connectors/feiqiu/docs/business-rules/index_algorithm_cn.md` |
|
||
| BaseDwsTask 机制 | `apps/etl/connectors/feiqiu/docs/etl_tasks/base_task_mechanism.md` |
|
||
| BD 手册(DWS 表) | `apps/etl/connectors/feiqiu/docs/database/DWS/main/` |
|
||
| DWD-DOC 权威规则 | `.kiro/steering/dwd-doc-authority.md` |
|
||
|
||
## 与其他文档的优先级
|
||
|
||
DWS 层开发时的参考优先级:DWD-DOC > 本文档 > BD 手册 > ETL 任务文档 > 业务规则文档 > DDL 注释。
|
||
|
||
> 本文档基于 2026-03-19 对项目代码、配置表、BD 手册和审计记录的全面收集整理。
|