# Model Param CSV Alignment Backend Implementation Plan > **For Claude:** REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task. **Goal:** Align system default model parameters with `assets/模型默认参数.csv` on the backend and database side without changing the existing `listAll/saveAll` API contract. **Architecture:** Keep `ccdi_model_param` as the single source of truth for model metadata and default values. Update initialization SQL, add an upgrade SQL for existing environments, and make a small service/mapper cleanup so query ordering and default-project copy behavior remain stable while historical `custom` projects stay untouched. **Tech Stack:** Java 21, Spring Boot 3, MyBatis Plus, MySQL, Maven --- ### Task 1: 固化 CSV 对应的系统默认参数清单 **Files:** - Reference: `assets/模型默认参数.csv` - Modify: `sql/ccdi_model_param.sql` **Step 1: 对照 CSV 列出最终参数集合** 确认最终系统默认参数为 5 个模型、16 个参数: - `LARGE_TRANSACTION` - `SUSPICIOUS_PART_TIME` - `SUSPICIOUS_FOREIGN_EXCHANGE` - `ABNORMAL_BEHAVIOR` - `SUSPICIOUS_GAMBLING` 并确认每条记录的 `model_code`、`model_name`、`param_code`、`param_name`、`param_desc`、`param_value`、`param_unit`、`sort_order`。 **Step 2: 写一个失败前检查** 运行: ```bash Get-Content -Raw 'sql/ccdi_model_param.sql' ``` 预期:可以看到旧参数定义仍与 CSV 不完全一致,包含已废弃参数或缺失模型。 **Step 3: 更新初始化 SQL** 将 `sql/ccdi_model_param.sql` 中 `project_id = 0` 的初始化数据改为与 CSV 一致,要求: - 删除旧的废弃参数 - 新增 `ABNORMAL_BEHAVIOR`、`SUSPICIOUS_GAMBLING` - 保证 `sort_order` 从 1 开始递增 - 不引入任何千分位格式数据 **Step 4: 做静态自检** 运行: ```bash Get-Content -Raw 'sql/ccdi_model_param.sql' ``` 预期:SQL 中只剩 CSV 对应的 16 条系统默认参数记录。 **Step 5: 提交** ```bash git add sql/ccdi_model_param.sql git commit -m "feat: 对齐模型默认参数初始化脚本" ``` ### Task 2: 为已有环境补充默认参数覆盖脚本 **Files:** - Create or Modify: `sql/2026-03-16-update-ccdi-model-param-defaults.sql` **Step 1: 写覆盖脚本骨架** 脚本要求: - 以事务包裹 - 只处理 `project_id = 0` - 先删除旧的系统默认参数 - 再插入与 CSV 一致的 16 条新默认参数 **Step 2: 写失败前检查** 运行: ```bash Test-Path 'sql/2026-03-16-update-ccdi-model-param-defaults.sql' Get-Content -Raw 'sql/2026-03-16-update-ccdi-model-param-defaults.sql' ``` 预期:若文件已存在,内容可能未完全符合最终参数集合;若不存在,则本步骤补齐。 **Step 3: 写最小正确实现** 确保脚本满足: - `START TRANSACTION;` - `DELETE FROM ccdi_model_param WHERE project_id = 0;` - 插入 16 条目标数据 - `COMMIT;` **Step 4: 自检** 运行: ```bash Get-Content -Raw 'sql/2026-03-16-update-ccdi-model-param-defaults.sql' ``` 预期:脚本与初始化 SQL 的系统默认参数集合完全一致。 **Step 5: 提交** ```bash git add sql/2026-03-16-update-ccdi-model-param-defaults.sql git commit -m "feat: 新增模型默认参数升级脚本" ``` ### Task 3: 稳定后端查询顺序 **Files:** - Modify: `ccdi-project/src/main/resources/mapper/ccdi/project/CcdiModelParamMapper.xml` **Step 1: 先查看当前 SQL** 运行: ```bash Get-Content -Raw 'ccdi-project/src/main/resources/mapper/ccdi/project/CcdiModelParamMapper.xml' ``` 预期:`selectByProjectId` 已存在,但排序可能仅依赖 `model_code, sort_order`。 **Step 2: 写一个小改动** 将 `selectByProjectId` 的排序改为稳定排序: ```xml ORDER BY model_code, sort_order, id ``` 如有必要,也检查 `selectByProjectAndModel` 是否需要补 `id` 兜底排序。 **Step 3: 静态验证** 运行: ```bash Get-Content -Raw 'ccdi-project/src/main/resources/mapper/ccdi/project/CcdiModelParamMapper.xml' ``` 预期:查询排序稳定,不依赖数据库默认返回顺序。 **Step 4: 提交** ```bash git add ccdi-project/src/main/resources/mapper/ccdi/project/CcdiModelParamMapper.xml git commit -m "fix: 稳定模型参数查询顺序" ``` ### Task 4: 清理服务层的 CSV 对齐边界 **Files:** - Modify: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiModelParamServiceImpl.java` **Step 1: 查看当前实现** 运行: ```bash Get-Content -Raw 'ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiModelParamServiceImpl.java' ``` 预期:当前已经支持 `listAll/saveAll`,但需要确认注释、排序依赖和默认项目复制逻辑是否与本次设计一致。 **Step 2: 写最小修正** 仅做与本次设计直接相关的修正: - 保持 `projectId=0/default/custom` 的现有读取规则 - 保持默认项目首次保存时复制系统默认参数全集 - 不增加任何历史 `custom` 项目补齐逻辑 - 不引入任何千分位处理逻辑 - 如有重复或无效的局部变量,顺手清理为更直接的实现 **Step 3: 写失败前验证** 运行: ```bash mvn -pl ccdi-project -am -DskipTests compile ``` 预期:若存在语法或导入问题,本步先暴露出来。 **Step 4: 调整到编译通过** 修正编译问题后再次运行: ```bash mvn -pl ccdi-project -am -DskipTests compile ``` 预期:BUILD SUCCESS。 **Step 5: 提交** ```bash git add ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiModelParamServiceImpl.java git commit -m "refactor: 收敛模型参数服务对齐逻辑" ``` ### Task 5: 验证新旧环境脚本产物一致 **Files:** - Reference: `sql/ccdi_model_param.sql` - Reference: `sql/2026-03-16-update-ccdi-model-param-defaults.sql` - Optional Record: `docs/tests/records/model-param-backend-alignment-test.md` **Step 1: 准备校验项** 至少检查: - 模型总数是否为 5 - 参数总数是否为 16 - 每个 `model_code + param_code` 唯一 - 所有 `param_value` 为原始字符串,不含千分位逗号 **Step 2: 执行静态比对** 运行: ```bash Get-Content -Raw 'sql/ccdi_model_param.sql' Get-Content -Raw 'sql/2026-03-16-update-ccdi-model-param-defaults.sql' ``` 预期:两个脚本中的系统默认参数集合一致。 **Step 3: 如本地有数据库,执行 SQL 验证** 示例: ```sql SELECT model_code, COUNT(*) AS cnt FROM ccdi_model_param WHERE project_id = 0 GROUP BY model_code ORDER BY model_code; ``` ```sql SELECT model_code, param_code, param_value FROM ccdi_model_param WHERE project_id = 0 ORDER BY model_code, sort_order, id; ``` 预期:返回结果与 CSV 一致。 **Step 4: 记录结果** 将验证过程写入: ```text docs/tests/records/model-param-backend-alignment-test.md ``` **Step 5: 提交** ```bash git add docs/tests/records/model-param-backend-alignment-test.md git commit -m "test: 记录模型默认参数后端对齐验证" ``` ### Task 6: 验证接口行为不变 **Files:** - Reference: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/controller/CcdiModelParamController.java` - Reference: `ruoyi-ui/src/api/ccdi/modelParam.js` **Step 1: 启动后端** 运行: ```bash mvn -pl ruoyi-admin -am spring-boot:run ``` **Step 2: 验证查询接口** 使用 Swagger 或 HTTP 工具请求: ```http GET /ccdi/modelParam/listAll?projectId=0 ``` 预期: - 返回 `models` 数组 - 包含 5 个模型 - 各模型参数与 CSV 一致 **Step 3: 验证默认项目查询** 对一个 `configType=default` 项目请求: ```http GET /ccdi/modelParam/listAll?projectId= ``` 预期:返回系统默认参数全集。 **Step 4: 验证默认项目首次保存** 调用: ```http POST /ccdi/modelParam/saveAll ``` 请求体示例: ```json { "projectId": 123, "models": [ { "modelCode": "LARGE_TRANSACTION", "params": [ { "paramCode": "SINGLE_TRANSACTION_AMOUNT", "paramValue": "2222" } ] } ] } ``` 预期: - 保存成功 - 该项目 `config_type` 变为 `custom` - 项目参数表中只复制当前系统默认参数全集,不补历史 `custom` 项目 **Step 5: 停止后端进程并提交** 测试结束后关闭 `mvn spring-boot:run` 启动的进程,再提交测试记录: ```bash git add docs/tests/records/model-param-backend-alignment-test.md git commit -m "test: 完成模型参数后端接口回归验证" ``` --- Plan complete and saved to `docs/plans/backend/2026-03-16-model-param-csv-alignment-backend-implementation.md`.