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
package org.jeecg.modules.dnc.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.jeecg.modules.dnc.entity.PartsDepartment;
import org.jeecg.modules.dnc.mapper.PartsDepartmentMapper;
import org.jeecg.modules.dnc.utils.ValidateUtil;
import org.jeecg.modules.dnc.service.IPartsDepartmentService;
import org.apache.commons.collections4.ListUtils;
import org.jeecg.modules.system.entity.MdcProduction;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.util.ArrayList;
import java.util.List;
 
@Service
public class PartsDepartmentServiceImpl extends ServiceImpl<PartsDepartmentMapper, PartsDepartment> implements IPartsDepartmentService {
    @Override
    @Transactional(rollbackFor = {Exception.class})
    public boolean deleteByPartsId(String partsId) {
        if(!ValidateUtil.validateString(partsId))
            return false;
        LambdaQueryWrapper<PartsDepartment> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(PartsDepartment::getPartsId, partsId);
        return super.remove(lambdaQueryWrapper);
    }
 
    @Override
    public List<MdcProduction> getDepartPermsByPartsId(String partsId) {
        return super.getBaseMapper().getDepartPermsByPartsId(partsId);
    }
 
    @Override
    public List<MdcProduction> getDepartNonPermsByProductId(String partsId) {
        return super.getBaseMapper().getDepartNonPermsByPartsId(partsId);
    }
 
    @Override
    public PartsDepartment getByPartsIdAndDepartId(String partsId, String departId) {
        if(!ValidateUtil.validateString(partsId) || !ValidateUtil.validateString(departId))
            return null;
        List<PartsDepartment> list = super.lambdaQuery().eq(PartsDepartment::getPartsId, partsId).eq(PartsDepartment::getDepartId, departId).list();
        if(list == null || list.isEmpty())
            return null;
        return list.get(0);
    }
 
    @Override
    @Transactional(rollbackFor = {Exception.class})
    public boolean removeByCollection(List<PartsDepartment> partsDepartments) {
        if(partsDepartments == null || partsDepartments.isEmpty())
            return false;
        if(partsDepartments.size() == 1)
            return super.removeById(partsDepartments.get(0).getPartsDepartId());
        List<String> ids = new ArrayList<>();
        partsDepartments.forEach(item -> {
            ids.add(item.getPartsDepartId());
        });
        if(ids.size() > 1000){
            List<List<String>> idsArr = ListUtils.partition(ids, 1000);
            for(List<String> arr : idsArr){
                super.removeByIds(arr);
            }
            return true;
        }else {
            return super.removeByIds(ids);
        }
    }
 
    @Override
    public List<PartsDepartment> getByPartsIdsAndDepartIds(List<String> partsIds, List<String> departIds) {
        if(partsIds == null || partsIds.isEmpty() || departIds == null || departIds.isEmpty())
            return null;
        List<PartsDepartment> total = new ArrayList<>();
        List<List<String>> partListArr;
        List<List<String>> departListArr;
        if(partsIds.size() > 1000){
            partListArr = ListUtils.partition(partsIds, 100);
        }else {
            partListArr = ListUtils.partition(partsIds, 1000);
        }
        if(departIds.size() > 1000){
            departListArr = ListUtils.partition(departIds, 100);
        }else {
            departListArr = ListUtils.partition(departIds, 1000);
        }
        for(List<String> partList : partListArr) {
            for(List<String> departList : departListArr){
                LambdaQueryWrapper<PartsDepartment> queryWrapper = Wrappers.lambdaQuery();
                queryWrapper.in(PartsDepartment::getPartsId, partList);
                queryWrapper.in(PartsDepartment::getDepartId, departList);
                List<PartsDepartment> list = super.list(queryWrapper);
                if(list != null && !list.isEmpty()){
                    total.addAll(list);
                }
            }
        }
        return total;
    }
}