(ofeata): 新增批量插入工资明细功能
- 在 IOaSalaryDetailService 中添加 insertBatchByBo 方法 - 在 IOaSalaryMasterService 中添加 batchInsertDetails 方法 - 实现 OaSalaryDetailServiceImpl 和 OaSalaryMasterServiceImpl 中的批量插入逻辑 - 更新OaSalaryMasterBo 和 OaSalaryMasterController 以支持批量插入功能
This commit is contained in:
@@ -2,7 +2,6 @@ package com.ruoyi.oa.controller;
|
|||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
@@ -16,7 +15,6 @@ import com.ruoyi.common.core.domain.PageQuery;
|
|||||||
import com.ruoyi.common.core.domain.R;
|
import com.ruoyi.common.core.domain.R;
|
||||||
import com.ruoyi.common.core.validate.AddGroup;
|
import com.ruoyi.common.core.validate.AddGroup;
|
||||||
import com.ruoyi.common.core.validate.EditGroup;
|
import com.ruoyi.common.core.validate.EditGroup;
|
||||||
import com.ruoyi.common.core.validate.QueryGroup;
|
|
||||||
import com.ruoyi.common.enums.BusinessType;
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
import com.ruoyi.common.utils.poi.ExcelUtil;
|
import com.ruoyi.common.utils.poi.ExcelUtil;
|
||||||
import com.ruoyi.oa.domain.vo.OaSalaryMasterVo;
|
import com.ruoyi.oa.domain.vo.OaSalaryMasterVo;
|
||||||
@@ -98,4 +96,17 @@ public class OaSalaryMasterController extends BaseController {
|
|||||||
@PathVariable Long[] masterIds) {
|
@PathVariable Long[] masterIds) {
|
||||||
return toAjax(iOaSalaryMasterService.deleteWithValidByIds(Arrays.asList(masterIds), true));
|
return toAjax(iOaSalaryMasterService.deleteWithValidByIds(Arrays.asList(masterIds), true));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量插入工资明细(方式一:使用OaSalaryMasterBo)
|
||||||
|
*
|
||||||
|
* @param bo 包含主表信息和明细列表的业务对象
|
||||||
|
*/
|
||||||
|
@Log(title = "批量插入工资明细", businessType = BusinessType.INSERT)
|
||||||
|
@RepeatSubmit()
|
||||||
|
@PostMapping("/batchInsertDetails")
|
||||||
|
public R<Void> batchInsertDetails(@Validated(AddGroup.class) @RequestBody OaSalaryMasterBo bo) {
|
||||||
|
return toAjax(iOaSalaryMasterService.batchInsertDetails(bo));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import lombok.EqualsAndHashCode;
|
|||||||
import javax.validation.constraints.*;
|
import javax.validation.constraints.*;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import com.ruoyi.common.core.domain.BaseEntity;
|
import com.ruoyi.common.core.domain.BaseEntity;
|
||||||
|
|
||||||
@@ -66,5 +67,10 @@ public class OaSalaryMasterBo extends BaseEntity {
|
|||||||
*/
|
*/
|
||||||
private String remark;
|
private String remark;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 工资明细列表
|
||||||
|
*/
|
||||||
|
private List<OaSalaryDetailBo> salaryDetailList;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,4 +46,9 @@ public interface IOaSalaryDetailService {
|
|||||||
* 校验并批量删除工资发放明细信息
|
* 校验并批量删除工资发放明细信息
|
||||||
*/
|
*/
|
||||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量插入工资发放明细
|
||||||
|
*/
|
||||||
|
Boolean insertBatchByBo(List<OaSalaryDetailBo> boList);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,4 +46,9 @@ public interface IOaSalaryMasterService {
|
|||||||
* 校验并批量删除工资发放主信息
|
* 校验并批量删除工资发放主信息
|
||||||
*/
|
*/
|
||||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 批量插入工资明细
|
||||||
|
*/
|
||||||
|
Boolean batchInsertDetails(OaSalaryMasterBo bo);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package com.ruoyi.oa.service.impl;
|
package com.ruoyi.oa.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
import com.ruoyi.common.core.domain.PageQuery;
|
import com.ruoyi.common.core.domain.PageQuery;
|
||||||
@@ -139,4 +140,20 @@ public class OaSalaryDetailServiceImpl implements IOaSalaryDetailService {
|
|||||||
}
|
}
|
||||||
return baseMapper.deleteBatchIds(ids) > 0;
|
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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package com.ruoyi.oa.service.impl;
|
package com.ruoyi.oa.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
import com.ruoyi.common.core.domain.PageQuery;
|
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 com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import com.ruoyi.oa.domain.bo.OaSalaryMasterBo;
|
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.vo.OaSalaryMasterVo;
|
||||||
import com.ruoyi.oa.domain.OaSalaryMaster;
|
import com.ruoyi.oa.domain.OaSalaryMaster;
|
||||||
|
import com.ruoyi.oa.domain.OaSalaryDetail;
|
||||||
import com.ruoyi.oa.mapper.OaSalaryMasterMapper;
|
import com.ruoyi.oa.mapper.OaSalaryMasterMapper;
|
||||||
import com.ruoyi.oa.service.IOaSalaryMasterService;
|
import com.ruoyi.oa.service.IOaSalaryMasterService;
|
||||||
|
import com.ruoyi.oa.service.IOaSalaryDetailService;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@@ -30,6 +35,7 @@ import java.util.Collection;
|
|||||||
public class OaSalaryMasterServiceImpl implements IOaSalaryMasterService {
|
public class OaSalaryMasterServiceImpl implements IOaSalaryMasterService {
|
||||||
|
|
||||||
private final OaSalaryMasterMapper baseMapper;
|
private final OaSalaryMasterMapper baseMapper;
|
||||||
|
private final IOaSalaryDetailService salaryDetailService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询工资发放主
|
* 查询工资发放主
|
||||||
@@ -112,4 +118,38 @@ public class OaSalaryMasterServiceImpl implements IOaSalaryMasterService {
|
|||||||
}
|
}
|
||||||
return baseMapper.deleteBatchIds(ids) > 0;
|
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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user