liukangdong
2025-03-11 ccfd4adf5fbc53ca8026234ed7631c2b3961abd6
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
package com.doumee.service.business.impl;
 
import com.doumee.service.business.third.model.PageData;
import com.doumee.service.business.third.model.PageWrap;
import com.doumee.core.utils.Constants;
import com.doumee.dao.business.ParksMapper;
import com.doumee.dao.business.join.ParksJoinMapper;
import com.doumee.dao.business.model.Parks;
import com.doumee.service.business.ParksService;
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;
import java.util.Objects;
 
/**
 * 停车库信息表Service实现
 * @author 江蹄蹄
 * @date 2023/11/30 15:33
 */
@Service
public class ParksServiceImpl implements ParksService {
 
    @Autowired
    private ParksMapper parksMapper;
 
    @Autowired
    private ParksJoinMapper parksJoinMapper;
 
 
    @Override
    public Integer create(Parks parks) {
        parksMapper.insert(parks);
        return parks.getId();
    }
 
    @Override
    public void deleteById(Integer id) {
        parksMapper.deleteById(id);
    }
 
    @Override
    public void delete(Parks parks) {
        UpdateWrapper<Parks> deleteWrapper = new UpdateWrapper<>(parks);
        parksMapper.delete(deleteWrapper);
    }
 
    @Override
    public void deleteByIdInBatch(List<Integer> ids) {
        if (CollectionUtils.isEmpty(ids)) {
            return;
        }
        parksMapper.deleteBatchIds(ids);
    }
 
    @Override
    public void updateById(Parks parks) {
        parksMapper.updateById(parks);
    }
 
    @Override
    public void updateByIdInBatch(List<Parks> parkss) {
        if (CollectionUtils.isEmpty(parkss)) {
            return;
        }
        for (Parks parks: parkss) {
            this.updateById(parks);
        }
    }
 
    @Override
    public Parks findById(Integer id) {
        return parksMapper.selectById(id);
    }
 
    @Override
    public Parks findOne(Parks parks) {
        QueryWrapper<Parks> wrapper = new QueryWrapper<>(parks);
        return parksMapper.selectOne(wrapper);
    }
 
    @Override
    public List<Parks> findList(Parks parks) {
        MPJLambdaWrapper<Parks> queryWrapper = new MPJLambdaWrapper<>();
        queryWrapper.isNull(Parks::getParentHkId);
        queryWrapper.eq(Parks::getIsdeleted,Constants.ZERO);
        queryWrapper.orderByDesc(Parks::getCreateDate);
        return parksMapper.selectList(queryWrapper);
    }
  
    @Override
    public PageData<Parks> findPage(PageWrap<Parks> pageWrap) {
        IPage<Parks> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        MPJLambdaWrapper<Parks> queryWrapper = new MPJLambdaWrapper<>();
        queryWrapper.selectAll(Parks.class);
        queryWrapper.select(" p.name as parentName");
 
        queryWrapper.leftJoin(" parks p on p.id=t.PARENT_HK_ID");
 
        queryWrapper.eq(Parks::getIsdeleted, Constants.ZERO);
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()),Parks::getName,pageWrap.getModel().getName());
        queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getParentHkId()),Parks::getParentHkId,pageWrap.getModel().getParentHkId());
        queryWrapper.orderByDesc(Parks::getCreateDate);
        IPage<Parks> result = parksJoinMapper.selectJoinPage(page, Parks.class,queryWrapper);
        return PageData.from(result);
    }
 
    @Override
    public long count(Parks parks) {
        QueryWrapper<Parks> wrapper = new QueryWrapper<>(parks);
        return parksMapper.selectCount(wrapper);
    }
}