变更审计记录:绩效页数据正确性修复
| 字段 |
值 |
| 日期 |
2026-03-24 18:19:34 |
| Prompt-ID |
P20260324-180413 |
| Session-ID |
02057e57 |
| Session 路径 |
docs/audit/session_logs/2026-03/24/56_df6dc5a7_123842 |
操作摘要
修复绩效页(PERF-1)多个字段数据不正确的问题:当前档位费率显示客户收费标准而非助教到手单价、下一阶段费率/小时数/奖金全为 0、收入明细缺少激励课和 Top3 销冠奖项。涉及 fdw_queries.py SQL 查询扩展和 performance_service.py 业务逻辑重写。
变更文件
| 文件 |
变更类型 |
apps/backend/app/services/fdw_queries.py |
修改 |
apps/backend/app/services/performance_service.py |
修改 |
本次对话文件变更
新增文件
docs/audit/prompt_logs/prompt_log_20260324_180413.md
docs/audit/session_logs/2026-03/24/56_df6dc5a7_123842/main_01_02057e57.md
docs/audit/session_logs/2026-03/24/56_df6dc5a7_123842/sub_01_02057e57.md
docs/audit/session_logs/2026-03/24/57_5d61a787_175819/main_01_b8040cd9.md
docs/audit/session_logs/2026-03/24/57_5d61a787_175819/sub_01_02057e57.md
改动注解
apps/backend/app/services/fdw_queries.py
- 变更类型:修改
- 原始原因:绩效页收入明细需要奖金拆分(top_rank_bonus、recharge_commission、other_bonus)和当前档位抽成参数(base_deduction、bonus_deduction_ratio),原
get_salary_calc() 未查询这些字段
- 思路分析:在
get_salary_calc() 的 SQL SELECT 中追加 5 个字段(top_rank_bonus、recharge_commission、other_bonus、base_deduction、bonus_deduction_ratio),均来自 app.v_dws_assistant_salary_calc 视图已有列。返回 dict 增加对应键值,保持与现有字段相同的 float 转换 + None 默认值模式
- 修改结果:
performance_service.py 可获取奖金拆分数据和抽成参数,用于计算助教到手单价和收入明细展示。影响范围:仅 get_salary_calc() 的调用方(performance_service.get_overview() 和 task_manager)
apps/backend/app/services/performance_service.py
- 变更类型:修改
- 原始原因:绩效页 6 个数据错误——(1) currentTier 费率显示客户收费标准而非助教到手单价 (2) nextTier 费率全为 0 (3) upgradeHoursNeeded 为 0 (4) upgradeBonus 为 0 (5) 收入明细只显示有数据项,缺少激励课和 Top3 销冠奖 (6) total_bonus=600 未在明细中展示
- 思路分析:
- 到手单价计算:基础课到手 = 客户价 - base_deduction(球房提成固定额);激励课到手 = 客户价 × (1 - bonus_deduction_ratio)(球房提成比例)。从
get_salary_calc() 新增的 base_deduction/bonus_deduction_ratio 字段获取
- 档位进度:新增调用
fdw_queries.get_performance_tiers() 读取 cfg_performance_tier 配置表,遍历找到当前档和下一档,计算 upgradeHoursNeeded = next_tier.min_hours - total_hours,upgradeBonus = 升档后抽成降低的节省额。逻辑复用自 task_manager._build_performance_summary
- 收入明细:
_build_income_items() 改为始终显示 3 项(基础课、激励课、Top3 销冠奖),即使金额为 0。Top3 销冠奖为 0 时 desc 显示"继续努力"。新增 top_rank_bonus 参数
- 修改结果:绩效页所有字段数据正确——currentTier basicRate=80/incentiveRate=95,nextTier basicRate=90/incentiveRate=114,upgradeHoursNeeded=12.91,upgradeBonus=1200,incomeItems 含 3 项(基础课¥8,567.20 + 激励课¥0.00 + Top3 销冠奖¥600.00)。影响范围:仅 PERF-1 概览接口
GET /api/xcx/performance
合规检查
| 检查项 |
状态 |
| 新增迁移 SQL |
无 |
| DDL 基线更新 |
不适用 |
| OpenAPI Spec 同步 |
不适用(接口签名未变,仅响应数据值修正) |
| BD 手册更新 |
不适用(未新增表/字段) |
| 文档同步 |
✅ 已更新 AI_CHANGELOG |