10 KiB
员工亲属资产维护后端实施计划
For Claude: REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.
Goal: 为员工亲属关系维护页面补齐亲属资产的后端聚合保存、详情查询、删除级联和异步导入能力。
Architecture: 以 CcdiStaffFmyRelation 为聚合根扩展 assetInfoList,由资产模块负责持久化和导入,由亲属关系服务负责在新增、编辑、删除、详情等场景中协调资产数据。编辑时通过固定的 family_id + person_id 覆盖重建亲属资产,不引入额外关联字段。
Tech Stack: Java 21, Spring Boot 3, MyBatis Plus, MyBatis XML, Redis, EasyExcel, Lombok
Task 1: 补齐资产表 SQL 与索引设计
Files:
- Create:
D:\ccdi\ccdi\sql\ccdi_asset_info.sql - Check:
D:\ccdi\ccdi\docs\plans\2026-03-12-staff-family-asset-maintenance-design.md
Step 1: 写出资产表建表 SQL
- 新增
ccdi_asset_info - 主键使用
asset_id BIGINT AUTO_INCREMENT - 字段包含
family_id、person_id和资产业务字段 - 审计字段遵循项目现有风格
Step 2: 为归属查询补索引
- 添加
idx_family_id - 添加
idx_person_id - 添加联合索引
idx_family_person
Step 3: 自查字段口径
- 确认
family_id保存员工证件号 - 确认
person_id保存亲属证件号 - 确认不新增
relation_id
Step 4: 记录执行命令
Run: Get-Content 'D:\ccdi\ccdi\sql\ccdi_asset_info.sql'
Expected: 能看到完整建表语句与索引定义
Step 5: 提交
git add sql/ccdi_asset_info.sql
git commit -m "新增亲属资产表结构设计"
Task 2: 创建资产领域对象与映射接口
Files:
- Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\CcdiAssetInfo.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\dto\CcdiAssetInfoDTO.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\vo\CcdiAssetInfoVO.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\excel\CcdiAssetInfoExcel.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\vo\AssetImportFailureVO.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\mapper\CcdiAssetInfoMapper.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\resources\mapper\info\collection\CcdiAssetInfoMapper.xml
Step 1: 创建领域实体与 DTO/VO
CcdiAssetInfo映射表字段CcdiAssetInfoDTO承载亲属关系聚合保存时的子表数据CcdiAssetInfoVO用于详情回显
Step 2: 创建 Excel 与失败记录对象
CcdiAssetInfoExcel用于模板下载与导入解析AssetImportFailureVO仅返回失败记录
Step 3: 定义 Mapper 能力
- 按
family_id + person_id查询资产列表 - 按
family_id + person_id删除资产 - 批量插入资产
- 导入场景下按亲属证件号查询归属员工候选
Step 4: 运行编译检查
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: 新增类与 XML 能被正常加载,无编译错误
Step 5: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain ccdi-info-collection/src/main/java/com/ruoyi/info/collection/mapper ccdi-info-collection/src/main/resources/mapper/info/collection/CcdiAssetInfoMapper.xml
git commit -m "新增亲属资产领域对象与映射"
Task 3: 实现资产服务与导入服务
Files:
- Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\ICcdiAssetInfoService.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\ICcdiAssetInfoImportService.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\impl\CcdiAssetInfoServiceImpl.java - Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\impl\CcdiAssetInfoImportServiceImpl.java
Step 1: 实现基础资产服务
- 查询当前亲属资产列表
- 按归属键删除资产
- 批量保存资产
- 过滤空行并校验必填字段、数值、日期
Step 2: 实现资产导入异步服务
- 初始化 Redis 状态
- 解析 Excel 数据
- 通过
relation_cert_no反查亲属关系 - 识别无法匹配和归属不唯一场景
- 仅缓存失败记录
Step 3: 明确 Redis Key 规则
- 状态 key:
import:assetInfo:{taskId} - 失败 key:
import:assetInfo:{taskId}:failures
Step 4: 运行编译检查
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: 服务接口与实现均编译通过
Step 5: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service
git commit -m "实现亲属资产服务与导入服务"
Task 4: 扩展亲属关系 DTO 与 VO 聚合资产列表
Files:
- Modify:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\dto\CcdiStaffFmyRelationAddDTO.java - Modify:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\dto\CcdiStaffFmyRelationEditDTO.java - Modify:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\domain\vo\CcdiStaffFmyRelationVO.java
Step 1: 为新增 DTO 增加 assetInfoList
- 类型使用
List<CcdiAssetInfoDTO> - 保持与前端子表数据结构一致
Step 2: 为编辑 DTO 增加 assetInfoList
- 与新增 DTO 保持一致
- 保留现有校验规则
Step 3: 为详情 VO 增加 assetInfoList
- 类型使用
List<CcdiAssetInfoVO> - 用于详情和编辑回显
Step 4: 编译验证
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: DTO、VO 依赖关系正常
Step 5: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/dto/CcdiStaffFmyRelationAddDTO.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/dto/CcdiStaffFmyRelationEditDTO.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/vo/CcdiStaffFmyRelationVO.java
git commit -m "扩展亲属关系聚合资产字段"
Task 5: 改造亲属关系服务聚合保存与详情查询
Files:
- Modify:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\impl\CcdiStaffFmyRelationServiceImpl.java - Check:
D:\ccdi\ccdi\ccdi-info-collection\src\main\resources\mapper\info\collection\CcdiStaffFmyRelationMapper.xml
Step 1: 注入资产服务
- 在服务实现中注入
ICcdiAssetInfoService
Step 2: 改造详情查询
- 查询亲属关系主记录
- 按
personId + relationCertNo查询资产列表 - 回填
assetInfoList
Step 3: 改造新增逻辑
- 保存亲属关系
- 回填资产归属键
- 批量保存资产
Step 4: 改造编辑逻辑
- 查询旧记录
- 校验证件类型、证件号码未被修改
- 更新主记录
- 删除旧资产
- 保存新资产列表
Step 5: 改造删除逻辑
- 根据待删 ID 先查询关系记录
- 循环按
family_id + person_id删除资产 - 再批量删除亲属关系
Step 6: 编译验证
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: 亲属关系服务改造后可通过编译
Step 7: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiStaffFmyRelationServiceImpl.java
git commit -m "改造亲属关系聚合保存亲属资产"
Task 6: 新增资产导入控制器并接入下载模板与状态查询
Files:
- Create:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\controller\CcdiAssetInfoController.java
Step 1: 添加模板下载接口
POST /ccdi/assetInfo/importTemplate
Step 2: 添加导入接口
POST /ccdi/assetInfo/importData- 解析 Excel 后提交异步任务
Step 3: 添加状态与失败记录接口
GET /ccdi/assetInfo/importStatus/{taskId}GET /ccdi/assetInfo/importFailures/{taskId}
Step 4: 核对权限标识
- 使用
ccdi:staffFmyRelation:import还是新增独立权限 - 若采用独立权限,记录需同步补菜单 SQL
Step 5: 编译验证
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: 控制器注册正常
Step 6: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiAssetInfoController.java
git commit -m "新增亲属资产导入控制器"
Task 7: 补充亲属关系编辑防御校验
Files:
- Modify:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\service\impl\CcdiStaffFmyRelationServiceImpl.java
Step 1: 查询旧记录
- 编辑保存前按
id查询旧关系
Step 2: 比较证件类型与证件号码
- 若值发生变化,抛出业务异常
Step 3: 明确错误文案
- 返回“关系人证件类型/证件号码不允许修改”
Step 4: 编译验证
Run: mvn -pl ccdi-info-collection -am -DskipTests compile
Expected: 校验逻辑编译通过
Step 5: 提交
git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiStaffFmyRelationServiceImpl.java
git commit -m "限制编辑亲属证件信息变更"
Task 8: 执行后端回归验证
Files:
- Check:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\controller\CcdiStaffFmyRelationController.java - Check:
D:\ccdi\ccdi\ccdi-info-collection\src\main\java\com\ruoyi\info\collection\controller\CcdiAssetInfoController.java
Step 1: 编译后端模块
Run: mvn -pl ccdi-info-collection -am clean compile
Expected: BUILD SUCCESS
Step 2: 启动应用后手工验证接口
Run: mvn -pl ruoyi-admin -am spring-boot:run
Expected: 应用可正常启动
Step 3: 验证关键场景
- 查询亲属关系详情返回
assetInfoList - 新增/编辑亲属关系能保存资产
- 删除亲属关系后资产被同步删除
- 亲属资产导入可生成任务状态和失败记录
Step 4: 整理验证记录
- 将实际验证结果补充到开发记录或 PR 描述
Step 5: 提交
git add .
git commit -m "完成亲属资产后端联调验证"