(ofeata): 新增批量插入工资明细功能

- 在 IOaSalaryDetailService 中添加 insertBatchByBo 方法
- 在 IOaSalaryMasterService 中添加 batchInsertDetails 方法
- 实现 OaSalaryDetailServiceImpl 和 OaSalaryMasterServiceImpl 中的批量插入逻辑
- 更新OaSalaryMasterBo 和 OaSalaryMasterController 以支持批量插入功能
This commit is contained in:
2025-09-08 15:56:55 +08:00
parent 655540c20b
commit f37e0eb53a
6 changed files with 86 additions and 2 deletions

View File

@@ -46,4 +46,9 @@ public interface IOaSalaryDetailService {
* 校验并批量删除工资发放明细信息
*/
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
/**
* 批量插入工资发放明细
*/
Boolean insertBatchByBo(List<OaSalaryDetailBo> boList);
}

View File

@@ -46,4 +46,9 @@ public interface IOaSalaryMasterService {
* 校验并批量删除工资发放主信息
*/
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
/**
* 批量插入工资明细
*/
Boolean batchInsertDetails(OaSalaryMasterBo bo);
}

View File

@@ -1,6 +1,7 @@
package com.ruoyi.oa.service.impl;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.domain.PageQuery;
@@ -139,4 +140,20 @@ public class OaSalaryDetailServiceImpl implements IOaSalaryDetailService {
}
return baseMapper.deleteBatchIds(ids) > 0;
}
/**
* 批量插入工资发放明细
*/
@Override
public Boolean insertBatchByBo(List<OaSalaryDetailBo> boList) {
if (CollUtil.isEmpty(boList)) {
return true;
}
List<OaSalaryDetail> detailList = BeanUtil.copyToList(boList, OaSalaryDetail.class);
// 数据校验
for (OaSalaryDetail detail : detailList) {
validEntityBeforeSave(detail);
}
return baseMapper.insertBatch(detailList);
}
}

View File

@@ -1,6 +1,7 @@
package com.ruoyi.oa.service.impl;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.domain.PageQuery;
@@ -9,11 +10,15 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.ruoyi.oa.domain.bo.OaSalaryMasterBo;
import com.ruoyi.oa.domain.bo.OaSalaryDetailBo;
import com.ruoyi.oa.domain.vo.OaSalaryMasterVo;
import com.ruoyi.oa.domain.OaSalaryMaster;
import com.ruoyi.oa.domain.OaSalaryDetail;
import com.ruoyi.oa.mapper.OaSalaryMasterMapper;
import com.ruoyi.oa.service.IOaSalaryMasterService;
import com.ruoyi.oa.service.IOaSalaryDetailService;
import java.util.List;
import java.util.Map;
@@ -30,6 +35,7 @@ import java.util.Collection;
public class OaSalaryMasterServiceImpl implements IOaSalaryMasterService {
private final OaSalaryMasterMapper baseMapper;
private final IOaSalaryDetailService salaryDetailService;
/**
* 查询工资发放主
@@ -112,4 +118,38 @@ public class OaSalaryMasterServiceImpl implements IOaSalaryMasterService {
}
return baseMapper.deleteBatchIds(ids) > 0;
}
/**
* 批量插入工资明细
*/
@Override
@Transactional(rollbackFor = Exception.class)
public Boolean batchInsertDetails(OaSalaryMasterBo bo) {
// 1. 先插入或更新主表信息
OaSalaryMaster master;
if (bo.getMasterId() != null) {
// 如果有主键,则更新主表
master = BeanUtil.toBean(bo, OaSalaryMaster.class);
validEntityBeforeSave(master);
baseMapper.updateById(master);
} else {
// 如果没有主键,则新增主表
master = BeanUtil.toBean(bo, OaSalaryMaster.class);
validEntityBeforeSave(master);
baseMapper.insert(master);
bo.setMasterId(master.getMasterId());
}
// 2. 批量插入明细
if (CollUtil.isNotEmpty(bo.getSalaryDetailList())) {
// 设置主表ID
for (OaSalaryDetailBo detail : bo.getSalaryDetailList()) {
detail.setMainId(master.getMasterId());
}
// 批量插入明细
return salaryDetailService.insertBatchByBo(bo.getSalaryDetailList());
}
return true;
}
}