Commit Graph

283 Commits

Author SHA1 Message Date
wkc
93f5be29ce docs(staff-enterprise-relation): 更新数据库设计文档,添加关联查询说明 2026-02-11 15:30:18 +08:00
wkc
b3e0f97f71 feat: 添加信贷客户家庭关系实体类 2026-02-11 15:29:20 +08:00
wkc
719f02bdad feat: 创建信贷客户家庭关系表 2026-02-11 15:28:35 +08:00
wkc
fd9e208fa3 docs(staff-enterprise-relation): 更新API文档,添加员工姓名字段说明
- 新增员工实体关系管理API文档
- 在列表接口和详情接口响应中添加personName字段
- 说明personName通过LEFT JOIN ccdi_base_staff表获取
- 如果personId在员工信息表中不存在,personName为null
2026-02-11 15:27:40 +08:00
wkc
9776d76d1a feat: 员工亲属关系导入添加身份证号存在性校验 2026-02-11 15:20:08 +08:00
wkc
97c9525c2d feat(staff-enterprise-relation): Task 8完成前端编译验证 2026-02-11 15:18:48 +08:00
wkc
af7ec6f43d fix: 调整身份证号验证顺序,避免空指针风险
- 将身份证号存在性检查移到基本数据验证之后
- 此时 personId 已确保不为空且格式正确
- 错误信息更准确,包含操作建议
2026-02-11 15:09:47 +08:00
wkc
1d5e31a2df feat(staff-enterprise-relation): 列表页面添加员工姓名列
- 在身份证号列后添加员工姓名列
- prop名称为personName,与后端VO类保持一致
- 列宽设置为100px
2026-02-11 15:05:12 +08:00
wkc
497e040c81 feat: 员工实体关系导入添加身份证号存在性校验 2026-02-11 15:00:17 +08:00
wkc
eec2f8ccef feat(staff-enterprise-relation): Task 6完成后端编译验证
 后端代码编译成功
 VO类包含personName字段
 Mapper XML LEFT JOIN查询正确
 更新实施笔记

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 14:59:00 +08:00
wkc
51efb477d8 test(staff-enterprise-relation): 添加员工姓名字段测试脚本
- 创建测试脚本验证接口返回personName字段
- 测试列表接口和详情接口
- 自动检查响应中是否包含personName字段

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 14:55:15 +08:00
wkc
6f66108a8e feat(staff-enterprise-relation): 列表查询添加员工姓名JOIN 2026-02-11 14:48:26 +08:00
wkc
17edc7208d feat(staff-enterprise-relation): 添加员工姓名字段到VO 2026-02-11 14:40:29 +08:00
wkc
e2ee494bba fix: 修复信贷客户家庭关系表-添加唯一约束和统一字段类型
- 添加唯一约束 uk_person_cert (person_id, relation_cert_no)
- 统一字段类型与员工表保持一致:
  - id: BIGINT(20)
  - person_id: VARCHAR(100)
  - status: INT(11)
  - created_by/updated_by: VARCHAR(100)
  - update_time: DATETIME NOT NULL
- 添加 IF NOT EXISTS 防止重复创建
- 添加表头注释说明创建时间和用途
2026-02-11 14:38:06 +08:00
wkc
e1a1083c21 docs(staff-enterprise-relation): 标记Task 1为已完成 2026-02-11 14:32:51 +08:00
wkc
866d3a20ac feat(staff-enterprise-relation): 完成Task 1 - 数据库索引检查和创建 2026-02-11 14:32:20 +08:00
wkc
1405264cb2 feat: 创建信贷客户家庭关系表 2026-02-11 14:30:02 +08:00
wkc
09519ab4ac Merge branch 'feat/staff-transfer-staff-id-validation' into dev_1
功能: 员工调动导入员工ID校验

新增功能:
- 批量预验证员工ID存在性(1次数据库查询)
- 错误信息包含Excel行号
- 主循环跳过已失败记录
- 完整的日志记录

技术实现:
- 添加 CcdiBaseStaffMapper 依赖注入
- 新增 batchValidateStaffIds() 方法
- 新增 isRowAlreadyFailed() 方法
- 修改 importTransferAsync() 主流程

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 13:57:13 +08:00
wkc
1c20bcd1ab docs: 更新员工调动导入API文档
添加员工ID验证相关的错误情况说明
- 员工ID不存在错误
- 批量验证机制说明
- 性能优化说明
- 更新日志
2026-02-11 13:53:09 +08:00
wkc
6f78e86d1c feat: 主循环跳过已失败的记录
在数据处理循环中添加检查逻辑,跳过已在预验证阶段标记为失败的记录

- 在主循环开始处添加失败记录检查
- 使用 isRowAlreadyFailed 方法判断
- 检查失败后使用 continue 跳过处理
- 避免对已失败记录进行不必要的验证和处理

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 13:47:55 +08:00
wkc
bf4b7107a4 feat: 在导入流程中添加员工ID批量验证
在数据处理循环前添加员工ID存在性验证阶段,提前标记无效员工ID的记录
2026-02-11 13:45:18 +08:00
wkc
e95abccf5d fix: 修复isRowAlreadyFailed方法的NPE风险
修复第387行潜在的空指针异常:
- 将 f.getStaffId().equals(excel.getStaffId())
- 改为 Objects.equals(f.getStaffId(), excel.getStaffId())
- 确保当staffId为null时不会抛出NPE

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 13:42:55 +08:00
wkc
73a46a2d0c feat: 实现检查行是否已失败方法
- 添加 isRowAlreadyFailed 方法用于检查行是否已在失败列表中
- 通过比较员工ID、调动日期、调动前部门ID、调动后部门ID判断行的唯一性
- 在 StaffTransferImportFailureVO 中添加 deptIdBefore 和 deptIdAfter 字段
- 使用 Stream API 的 anyMatch 方法实现高效的匹配判断

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 11:26:05 +08:00
wkc
933626f24f feat: 实现批量验证员工ID方法
- 提取Excel中所有员工ID并去重
- 批量查询数据库中存在的员工ID
- 标记不存在的员工ID为失败记录
- 记录详细的验证日志
- 新增ImportLogUtils工具类用于统一日志格式

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 11:16:58 +08:00
wkc
5f44984aa3 feat 导入日志 2026-02-11 11:13:20 +08:00
wkc
7505bf4b3f feat: 添加CcdiBaseStaffMapper依赖注入
为员工调动导入服务添加员工信息Mapper,用于批量验证员工ID存在性
2026-02-11 11:12:32 +08:00
wkc
03b721d92f docs: 添加员工调动导入员工ID校验设计文档
- 完成需求分析和架构设计
- 定义批量预验证方案
- 详述数据流和代码实现
- 列出边界情况和测试场景
- 分析性能影响范围

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-11 11:06:51 +08:00
wkc
6db63cd8b1 feat 员工调动记录 2026-02-11 10:42:38 +08:00
wkc
78a9300644 feat 员工亲属关系 2026-02-10 10:41:19 +08:00
wkc
bf19a9daa8 feat 员工亲属关系 2026-02-10 00:30:06 +08:00
wkc
9a7fedcd74 feat 员工实体关系 2026-02-09 21:27:20 +08:00
wkc
f7c8bd1c95 feat 2026-02-09 17:00:41 +08:00
wkc
02249c402e 文件夹整理 2026-02-09 14:28:25 +08:00
wkc
056d239041 移除无用组件 2026-02-09 09:43:36 +08:00
wkc
8efbd43abd 除员工外 取消导入更新 添加导入文件重复校验 2026-02-09 09:10:35 +08:00
wkc
886176ed7e 除员工外 取消导入更新 2026-02-09 02:18:56 +08:00
wkc
f96d10d2e8 feat: 移除招聘信和采购交易的导入更新支持功能
## 变更内容
- 移除招聘信和采购交易导入功能中的isUpdateSupport参数
- 遇到已存在的数据直接报错,不再支持更新操作
- 前端移除"是否更新"复选框

## 后端修改
- CcdiStaffRecruitmentController: 移除updateSupport参数
- ICcdiStaffRecruitmentService: 移除updateSupport参数
- CcdiStaffRecruitmentServiceImpl: 简化导入逻辑,移除更新支持
- CcdiPurchaseTransactionController: 移除updateSupport参数
- ICcdiPurchaseTransactionService: 移除updateSupport参数
- ICcdiPurchaseTransactionImportService: 移除updateSupport参数
- CcdiPurchaseTransactionServiceImpl: 移除updateSupport参数
- CcdiPurchaseTransactionImportServiceImpl: 简化导入逻辑,移除更新支持

## 前端修改
- ccdiStaffRecruitment/index.vue: 移除"是否更新"复选框和相关参数
- ccdiPurchaseTransaction/index.vue: 移除"是否更新"复选框和相关参数

## 影响范围
- 导入时遇到已存在的招聘项目编号或采购事项ID将直接报错
- 错误提示显示具体的重复ID
- 不再支持通过导入文件更新已存在的数据
2026-02-09 01:12:22 +08:00
wkc
26a225298a 导入测试 2026-02-09 00:13:32 +08:00
wkc
cf5e435992 docs: 添加中介导入历史清除功能完成报告
- 添加功能设计文档
- 添加功能完成总结报告
- 包含代码审查结果和后续优化建议

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 18:52:44 +08:00
wkc
b35d05a9c5 feat: 实现清除导入历史记录方法 2026-02-08 18:43:28 +08:00
wkc
51dc466d8e feat: 监听清除导入历史记录事件 2026-02-08 18:37:36 +08:00
wkc
1216ba98c9 feat: 导入时触发清除历史记录事件 2026-02-08 18:34:52 +08:00
wkc
ddc06b876a fix: 修复importPersonBatch方法返回类型
将Mapper接口的importPersonBatch返回类型从void改为int,
以正确返回ON DUPLICATE KEY UPDATE的影响行数。
2026-02-08 17:20:45 +08:00
wkc
5ec5913759 fix: 修复中介导入成功条数计算错误
问题:
- 导入成功条数显示为负数
- 原因:成功数量计算使用 validRecords.size() - failures.size()
- 但没有使用实际的数据库操作返回值

修复:
- saveBatchWithUpsert 和 saveBatch 方法现在返回 int
- 累加实际的数据库影响行数
- 使用 actualSuccessCount 变量跟踪真实成功数量

影响范围:
- CcdiIntermediaryPersonImportServiceImpl
- CcdiIntermediaryEntityImportServiceImpl
2026-02-08 17:18:18 +08:00
wkc
bb0d68c41d 合并中介导入功能优化
使用ON DUPLICATE KEY UPDATE优化中介信息批量导入功能:
- Mapper层: 添加importPersonBatch和importEntityBatch方法
- Service层: 重构导入逻辑,移除'先删除再插入'
- 性能提升: 更新模式下减少50%数据库操作
- 数据库: 创建person_id唯一索引

详见: doc/plans/2026-02-08-intermediary-import-on-duplicate-key-update-design.md

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:27:42 +08:00
wkc
717bfb67c5 docs: 添加Task 5&6完成报告
- 详细记录Service层重构过程
- 代码对比和性能分析
- 测试覆盖和验证点
- 后续建议和风险评估

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:25:08 +08:00
wkc
daf03e1ef0 test: 添加中介导入功能测试脚本和报告模板
- 添加自动化测试脚本 test-import-upsert.js
- 覆盖5个测试场景(首次导入、重复导入、更新等)
- 添加测试报告模板 TEST-REPORT-TEMPLATE.md

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:24:02 +08:00
wkc
7d534de54f refactor: 重构Service层使用ON DUPLICATE KEY UPDATE
- 更新模式直接调用importPersonBatch/importEntityBatch
- 移除'先删除再插入'逻辑,代码简化约50%
- 添加辅助方法saveBatchWithUpsert/getExistingPersonIdsFromDb
- 添加createFailureVO重载方法简化失败记录创建

变更详情:
- CcdiIntermediaryPersonImportServiceImpl: 重构importPersonAsync方法
- CcdiIntermediaryEntityImportServiceImpl: 重构importEntityAsync方法
- 两个Service均采用统一的处理模式

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:21:22 +08:00
wkc
161b2c880f refactor: 优化importEntityBatch方法签名
- 修改返回值类型从void改为int,与项目其他批量方法保持一致
- 更新JavaDoc注释,描述行为而不是实现细节
- 在XML中添加importEntityBatch的完整实现
- 使用ON DUPLICATE KEY UPDATE实现存在则更新,不存在则插入的功能

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:18:30 +08:00
wkc
894e376c9e docs: 补充importEntityBatch方法的JavaDoc @return标签
规范审查发现Task 3的JavaDoc注释不够完整,补充了@return标签说明无返回值。

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-08 16:13:43 +08:00