k94314517
2024-12-11 e80a6ad31c1e92899345eee9ab20b8f91693cd9b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
package com.doumee.service.business.impl;
 
import com.doumee.core.model.PageData;
import com.doumee.core.model.PageWrap;
import com.doumee.core.utils.Utils;
import com.doumee.dao.business.VisitParkMapper;
import com.doumee.dao.business.join.VisitParkJoinMapper;
import com.doumee.dao.business.model.*;
import com.doumee.service.business.VisitParkService;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
 
import java.util.List;
 
/**
 * 访客报备停车库关联表Service实现
 * @author 江蹄蹄
 * @since 2024/04/28 15:44
 */
@Service
public class VisitParkServiceImpl implements VisitParkService {
 
    @Autowired
    private VisitParkMapper visitParkMapper;
 
    @Autowired
    private VisitParkJoinMapper visitParkJoinMapper;
 
    @Override
    public Integer create(VisitPark visitPark) {
        visitParkMapper.insert(visitPark);
        return visitPark.getId();
    }
 
    @Override
    public void deleteById(Integer id) {
        visitParkMapper.deleteById(id);
    }
 
    @Override
    public void delete(VisitPark visitPark) {
        UpdateWrapper<VisitPark> deleteWrapper = new UpdateWrapper<>(visitPark);
        visitParkMapper.delete(deleteWrapper);
    }
 
    @Override
    public void deleteByIdInBatch(List<Integer> ids) {
        if (CollectionUtils.isEmpty(ids)) {
            return;
        }
        visitParkMapper.deleteBatchIds(ids);
    }
 
    @Override
    public void updateById(VisitPark visitPark) {
        visitParkMapper.updateById(visitPark);
    }
 
    @Override
    public void updateByIdInBatch(List<VisitPark> visitParks) {
        if (CollectionUtils.isEmpty(visitParks)) {
            return;
        }
        for (VisitPark visitPark: visitParks) {
            this.updateById(visitPark);
        }
    }
 
    @Override
    public VisitPark findById(Integer id) {
        return visitParkMapper.selectById(id);
    }
 
    @Override
    public VisitPark findOne(VisitPark visitPark) {
        QueryWrapper<VisitPark> wrapper = new QueryWrapper<>(visitPark);
        return visitParkMapper.selectOne(wrapper);
    }
 
    @Override
    public List<VisitPark> findList(VisitPark visitPark) {
        QueryWrapper<VisitPark> wrapper = new QueryWrapper<>(visitPark);
        return visitParkMapper.selectList(wrapper);
    }
  
    @Override
    public PageData<VisitPark> findPage(PageWrap<VisitPark> pageWrap) {
        IPage<VisitPark> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        MPJLambdaWrapper<VisitPark> queryWrapper = new MPJLambdaWrapper<>();
 
        queryWrapper.selectAll(VisitPark.class);
        queryWrapper.selectAs(Parks::getName, VisitPark::getParksName);
        queryWrapper.selectAs(Member::getType,VisitPark::getMemberType);
        queryWrapper.selectAs(Member::getName,VisitPark::getMemberName);
        queryWrapper.selectAs(Member::getPhone,VisitPark::getMemberPhone);
        queryWrapper.selectAs(Company::getName,VisitPark::getCompanyName);
 
        queryWrapper.leftJoin(Visits.class,Visits::getId,VisitPark::getVisitApplyId);
        queryWrapper.leftJoin(Parks.class,Parks::getId,VisitPark::getParkId);
        queryWrapper.leftJoin(Member.class,Member::getId,Visits::getMemberId);
        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
 
        queryWrapper
          .and(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()), ms->ms.like(Member::getPhone,pageWrap.getModel().getMemberName())
                .or().like(Member::getName,pageWrap.getModel().getMemberName()));
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCarCode()),VisitPark::getCarCode,pageWrap.getModel().getCarCode());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),Company::getName,pageWrap.getModel().getCompanyName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getParksName()),Parks::getName,pageWrap.getModel().getParksName());
        queryWrapper.orderByDesc(VisitPark::getCreateDate)
        ;
        IPage<VisitPark> result = visitParkJoinMapper.selectJoinPage(page, VisitPark.class,queryWrapper);
        return PageData.from(result);
    }
 
    @Override
    public long count(VisitPark visitPark) {
        QueryWrapper<VisitPark> wrapper = new QueryWrapper<>(visitPark);
        return visitParkMapper.selectCount(wrapper);
    }
}