ComputeItemCostRepository.java 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package com.kcim.dao.repository;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.kcim.common.util.UserContext;
  6. import com.kcim.dao.mapper.ComputeItemCostMapper;
  7. import com.kcim.dao.model.ComputeItemCost;
  8. import com.kcim.dao.model.dto.ComputeItemCostPageDto;
  9. import com.kcim.dao.model.dto.ComputeItemGroupByOrder;
  10. import com.kcim.dao.model.dto.ComputeItemGroupByVisitNoDto;
  11. import com.kcim.vo.SessionUserVO;
  12. import org.springframework.stereotype.Repository;
  13. import org.springframework.util.CollectionUtils;
  14. import java.util.ArrayList;
  15. import java.util.List;
  16. import java.util.stream.Collectors;
  17. /**
  18. * @program: CostAccount
  19. * @description: 收费项目成本计算数据库交互
  20. * @author: Wang.YS
  21. * @create: 2023-10-25 14:37
  22. **/
  23. @Repository
  24. public class ComputeItemCostRepository extends ServiceImpl<ComputeItemCostMapper, ComputeItemCost> {
  25. public List<Integer> removeByComputeDate(String computeDate, SessionUserVO currentUser) {
  26. LambdaQueryWrapper<ComputeItemCost> queryWrapper = new LambdaQueryWrapper<>();
  27. queryWrapper.eq(ComputeItemCost::getHospId, currentUser.getHospId());
  28. queryWrapper.eq(ComputeItemCost::getComputeDate,computeDate);
  29. List<ComputeItemCost> list = this.list(queryWrapper);
  30. if(!CollectionUtils.isEmpty(list)){
  31. List<Integer> collect = list.stream().map(ComputeItemCost::getId).collect(Collectors.toList());
  32. this.removeBatchByIds(collect,500);
  33. return collect;
  34. }
  35. return new ArrayList<>();
  36. }
  37. public Page<ComputeItemCostPageDto> getByPage(Integer current, Integer pageSize, String computeDate, String itemType, String itemName){
  38. Page<ComputeItemCostPageDto> page = new Page<>(current,pageSize);
  39. List<ComputeItemCostPageDto> byPage = this.baseMapper.getByPage(page, computeDate, itemType, itemName, UserContext.getHospId());
  40. if(!CollectionUtils.isEmpty(byPage)){
  41. page.setRecords(byPage);
  42. }
  43. return page;
  44. }
  45. public List<ComputeItemGroupByVisitNoDto> getByComputeDateGroupByVisitNo(String computeDate){
  46. return this.baseMapper.getListGroupByVisitNo(computeDate,UserContext.getHospId());
  47. }
  48. public List<ComputeItemGroupByOrder> getByComputeDateGroupByOrder(String computeDate){
  49. return this.baseMapper.getListGroupByOrder(computeDate,UserContext.getHospId());
  50. }
  51. }