jinpengyong
2021-12-20 b74c296ce3c58de5803b2cfea0f41efccb7b89cd
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
package com.moral.api.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.moral.api.entity.SysDictData;
import com.moral.api.entity.SysDictType;
import com.moral.api.mapper.SysDictDataMapper;
import com.moral.api.mapper.SysDictTypeMapper;
import com.moral.api.service.SysDictDataService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
 
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
 
/**
 * <p>
 * 字典表 服务实现类
 * </p>
 *
 * @author moral
 * @since 2021-03-09
 */
@Service
public class SysDictDataServiceImpl extends ServiceImpl<SysDictDataMapper, SysDictData> implements SysDictDataService {
 
    @Autowired
    private SysDictDataMapper sysDictDataMapper;
 
    @Autowired
    private SysDictTypeMapper sysDictTypeMapper;
 
    @Override
    public Map<String, Object> getSysDictDataByDictType(String type) {
        //根据字典类型名字获取字典类型id
        QueryWrapper<SysDictType> sysDictTypeQueryWrapper = new QueryWrapper<>();
        sysDictTypeQueryWrapper.select("id").eq("name", type);
        SysDictType sysDictType = sysDictTypeMapper.selectOne(sysDictTypeQueryWrapper);
 
        //根据字典类型id获取字典数据详情
        QueryWrapper<SysDictData> sysDictDataQueryWrapper = new QueryWrapper<>();
        sysDictDataQueryWrapper.select("dataKey", "dataValue").eq("dict_type_id", sysDictType.getId());
        List<SysDictData> sysDictData = sysDictDataMapper.selectList(sysDictDataQueryWrapper);
 
        return sysDictData.stream().collect(Collectors.toMap(SysDictData::getDataKey, SysDictData::getDataValue, (a, b) -> b));
    }
}