Files
ccdi/doc/plans/2026-02-26-model-param-save-optimization-plan.md

239 lines
5.0 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# 模型参数阈值更新接口优化实施计划
> **For Claude:** REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.
**Goal:** 简化模型参数保存接口的 DTO 结构,减少冗余字段
**Architecture:** 纯重构,不改变业务逻辑。简化 DTO 字段,同步更新 Service 和前端调用
**Tech Stack:** Java 17, Spring Boot, Vue.js
---
## Task 1: 简化后端 DTO
**Files:**
- Modify: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/domain/dto/ModelParamSaveDTO.java`
**Step 1: 读取当前 DTO 文件**
检查现有代码结构。
**Step 2: 重写 DTO 文件**
将整个文件替换为简化后的版本:
```java
package com.ruoyi.ccdi.project.domain.dto;
import lombok.Data;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import java.util.List;
/**
* 模型参数保存DTO
*/
@Data
public class ModelParamSaveDTO {
/** 项目ID */
private Long projectId;
/** 模型编码 */
@NotBlank(message = "模型编码不能为空")
private String modelCode;
/** 参数列表 */
@NotNull(message = "参数列表不能为空")
private List<ParamValueItem> params;
@Data
public static class ParamValueItem {
/** 参数编码 */
@NotBlank(message = "参数编码不能为空")
private String paramCode;
/** 参数值 - 唯一可修改字段 */
@NotBlank(message = "参数值不能为空")
private String paramValue;
}
}
```
**Step 3: 保存文件**
确保文件保存成功。
---
## Task 2: 更新 Service 层类型引用
**Files:**
- Modify: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiModelParamServiceImpl.java`
**Step 1: 更新 for 循环中的类型引用**
找到第 105 行附近的代码,将:
```java
for (ModelParamSaveDTO.ParamItem item : saveDTO.getParams()) {
```
改为:
```java
for (ModelParamSaveDTO.ParamValueItem item : saveDTO.getParams()) {
```
---
## Task 3: 简化前端请求参数
**Files:**
- Modify: `ruoyi-ui/src/views/ccdi/modelParam/index.vue`
**Step 1: 找到 handleSave 方法中的 saveDTO 构建**
定位到第 119-133 行。
**Step 2: 简化请求参数**
将原有的 saveDTO 构建代码:
```javascript
const saveDTO = {
projectId: this.queryParams.projectId,
modelCode: this.queryParams.modelCode,
modelName: this.modelList.find(
(m) => m.modelCode === this.queryParams.modelCode
)?.modelName,
params: modifiedParams.map((item) => ({
paramCode: item.paramCode,
paramName: item.paramName,
paramDesc: item.paramDesc,
paramValue: item.paramValue,
paramUnit: item.paramUnit,
sortOrder: item.sortOrder,
})),
};
```
替换为简化版本:
```javascript
const saveDTO = {
projectId: this.queryParams.projectId,
modelCode: this.queryParams.modelCode,
params: modifiedParams.map((item) => ({
paramCode: item.paramCode,
paramValue: item.paramValue,
})),
};
```
---
## Task 4: 编译后端验证
**Files:**
- 无文件修改,仅验证
**Step 1: 编译后端项目**
```bash
cd D:/ccdi/ccdi && mvn clean compile -DskipTests
```
**Expected:** BUILD SUCCESS
**Step 2: 如有编译错误,检查类型引用**
确保所有 `ParamItem` 都已改为 `ParamValueItem`
---
## Task 5: 功能测试验证
**Files:**
- 无文件修改,仅验证
**Step 1: 启动后端服务**
```bash
cd D:/ccdi/ccdi && mvn spring-boot:run
```
等待服务启动完成。
**Step 2: 通过 Swagger 测试保存接口**
1. 访问 `http://localhost:8080/swagger-ui/index.html`
2. 找到 `模型参数配置` 分组
3. 测试 `/ccdi/modelParam/save` 接口
4. 使用简化的请求体:
```json
{
"projectId": 0,
"modelCode": "LARGE_TRANSACTION",
"params": [
{
"paramCode": "SINGLE_AMOUNT",
"paramValue": "50000"
}
]
}
```
**Expected:** 返回 `{"code": 200, "msg": "保存成功"}`
**Step 3: 验证参数已更新**
调用 `/ccdi/modelParam/list?projectId=0&modelCode=LARGE_TRANSACTION`
**Expected:** 返回的参数中 `SINGLE_AMOUNT``paramValue` 已更新为 `50000`
---
## Task 6: 提交代码
**Step 1: 查看变更**
```bash
git status
git diff
```
**Step 2: 提交后端改动**
```bash
git add ccdi-project/src/main/java/com/ruoyi/ccdi/project/domain/dto/ModelParamSaveDTO.java
git add ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiModelParamServiceImpl.java
git commit -m "refactor: 简化 ModelParamSaveDTO移除冗余字段"
```
**Step 3: 提交前端改动**
```bash
git add ruoyi-ui/src/views/ccdi/modelParam/index.vue
git commit -m "refactor: 简化模型参数保存请求参数"
```
---
## 改动摘要
| 文件 | 改动 |
|------|------|
| `ModelParamSaveDTO.java` | 移除 modelNameParamItem 简化为 ParamValueItem2字段 |
| `CcdiModelParamServiceImpl.java` | 类型引用 ParamItem → ParamValueItem |
| `index.vue` | 请求参数只保留 paramCode 和 paramValue |
**风险等级:** 低(向后兼容,纯简化重构)
---
**创建日期:** 2026-02-26