From 3970ecc4f079b2acd840d876044eb6facc25ba6a Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期二, 30 一月 2024 20:07:44 +0800
Subject: [PATCH] 111

---
 server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java |   25 +++++++++++++++++++++----
 1 files changed, 21 insertions(+), 4 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
index f5ec6a9..a81f8fe 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
@@ -219,7 +219,8 @@
 
     @Override
     public List<Member> findListByDTO(MemberQueryDTO memberQueryDTO) {
-        List<Member> memberList = memberJoinMapper.selectJoinList(Member.class,new MPJLambdaWrapper<Member>()
+
+        MPJLambdaWrapper<Member> lambdaWrapper = new MPJLambdaWrapper<Member>()
                 .selectAll(Member.class)
                 .selectAs(DispatchUnit::getName,Member::getDuName)
                 .selectAs(Worktype::getName,Member::getWorkTypeName)
@@ -229,9 +230,25 @@
                 .eq(!Objects.isNull(memberQueryDTO.getCompanyId()),Member::getCompanyId,memberQueryDTO.getCompanyId())
                 .eq(Member::getIsdeleted, Constants.ZERO)
                 .like(StringUtils.isNotBlank(memberQueryDTO.getName()),Member::getName, memberQueryDTO.getName())
-                .notExists(!Objects.isNull(memberQueryDTO.getInsuranceApplyId()),
-                        " select 1 from apply_detail ad where ad.applyId = "+memberQueryDTO.getInsuranceApplyId()+" and ad.END_TIME > now() and ad.isdeleted = 0 " +
-                                " and ad.member_id = t.id ")
+                .notExists(!Objects.isNull(memberQueryDTO.getNotInInsuranceApplyId()),
+                        " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getNotInInsuranceApplyId()+" and ad.END_TIME > now() and ad.isdeleted = 0 " +
+                                " and ad.member_id = t.id ");
+        if(!Objects.isNull(memberQueryDTO.getInsuranceApplyId())){
+            lambdaWrapper = new MPJLambdaWrapper<Member>()
+                    .selectAll(Member.class)
+                    .selectAs(DispatchUnit::getName,Member::getDuName)
+                    .selectAs(Worktype::getName,Member::getWorkTypeName)
+                    .leftJoin(ApplyDetail.class,ApplyDetail::getMemberId,Member::getId)
+                    .leftJoin(InsuranceApply.class,InsuranceApply::getId,ApplyDetail::getApplyId)
+                    .leftJoin(DispatchUnit.class,DispatchUnit::getId,ApplyDetail::getDuId)
+                    .leftJoin(Worktype.class,Worktype::getId,ApplyDetail::getWorktypeId)
+                    .eq(Member::getIsdeleted, Constants.ZERO)
+                    .eq(InsuranceApply::getId,memberQueryDTO.getInsuranceApplyId())
+                    .exists(!Objects.isNull(memberQueryDTO.getInsuranceApplyId()),
+                            " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getInsuranceApplyId()+" and ad.END_TIME > now() and ad.isdeleted = 0 " +
+                                    " and ad.member_id = t.id ");
+        }
+        List<Member> memberList = memberJoinMapper.selectJoinList(Member.class,lambdaWrapper
         );
         return memberList;
     }

--
Gitblit v1.9.3