From fc4b360e4ce47c29cc96f941d37d22a225a139b1 Mon Sep 17 00:00:00 2001 From: whywhyo <1511349576@qq.com> Date: 星期六, 29 七月 2023 10:37:32 +0800 Subject: [PATCH] 56187 --- zhang-content/src/main/java/com/ruoyi/service/impl/ZTravelPriceServiceImpl.java | 22 ++++++++++++++++++++++ 1 files changed, 22 insertions(+), 0 deletions(-) diff --git a/zhang-content/src/main/java/com/ruoyi/service/impl/ZTravelPriceServiceImpl.java b/zhang-content/src/main/java/com/ruoyi/service/impl/ZTravelPriceServiceImpl.java index 64f1393..6ed0f80 100644 --- a/zhang-content/src/main/java/com/ruoyi/service/impl/ZTravelPriceServiceImpl.java +++ b/zhang-content/src/main/java/com/ruoyi/service/impl/ZTravelPriceServiceImpl.java @@ -21,6 +21,7 @@ import com.ruoyi.service.ZTravelBaseService; import com.ruoyi.service.ZTravelPriceDetailService; import com.ruoyi.service.ZTravelPriceService; +import org.apache.xmlbeans.impl.xb.xmlschema.LangAttribute; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -222,6 +223,7 @@ } @Override + @Transactional public AjaxResult myUpdate(PriceDto priceDto) { SysUser user = SecurityUtils.getLoginUser().getUser(); @@ -229,6 +231,26 @@ List<ZTravelPriceDetail> detailList = priceDto.getDetailList(); + //鍏堟煡鏁版嵁搴撻噷闈㈣繖涓�娆¤垂鐢ㄦ墍鏈夌殑鏁版嵁 + LambdaQueryWrapper<ZTravelPriceDetail> lqw = new LambdaQueryWrapper<>(); + lqw.eq(ZTravelPriceDetail::getFeeId,priceDto.getId()); + List<ZTravelPriceDetail> selectDetailList = zTravelPriceDetailService.list(lqw); + + //鎶婁紶杩囨潵鐨勬暟鎹腑娌℃湁鐨刬d锛屽湪鏁版嵁搴撲腑鍒犳帀 + List<Long> detailIdList = detailList.stream().filter(priceDetail -> priceDetail.getId() != null).map(ZTravelPriceDetail::getId).collect(Collectors.toList()); + List<Long> deleteIdList = selectDetailList.stream().filter(priceDetail -> !detailIdList.contains(priceDetail.getId())).map(ZTravelPriceDetail::getId).collect(Collectors.toList()); + zTravelPriceDetailService.removeBatchByIds(deleteIdList); + + + //濡傛灉浼犺繃鏉ョ殑鍒楄〃鐨勬暟鎹噷闈㈡病鏈塱d + List<ZTravelPriceDetail> addPriceDetail = detailList.stream().filter(priceDetail -> priceDetail.getId() == null || priceDetail.getId() == 0 ).collect(Collectors.toList()); + addPriceDetail.forEach(priceDetail -> { + priceDetail.setFeeId(priceDto.getId()); + }); + + //閭e氨鍏堝鍔犲埌鏁版嵁搴撲腑 + zTravelPriceDetailService.saveBatch(addPriceDetail); + //寰楀埌鎬诲ぉ鏁� long count = detailList.stream().map(ZTravelPriceDetail::getHappenTime).distinct().count(); Integer totalDay = Math.toIntExact(count); -- Gitblit v1.9.1