SysDictDataServiceImpl.java 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package com.ruoyi.system.service.impl;
  2. import cn.hutool.core.util.StrUtil;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.ruoyi.common.core.domain.entity.SysDictData;
  6. import com.ruoyi.common.core.page.TableDataInfo;
  7. import com.ruoyi.common.utils.DictUtils;
  8. import com.ruoyi.common.utils.PageUtils;
  9. import com.ruoyi.system.mapper.SysDictDataMapper;
  10. import com.ruoyi.system.service.ISysDictDataService;
  11. import org.springframework.stereotype.Service;
  12. import java.util.Arrays;
  13. import java.util.List;
  14. /**
  15. * 字典 业务层处理
  16. *
  17. * @author ruoyi
  18. */
  19. @Service
  20. public class SysDictDataServiceImpl extends ServiceImpl<SysDictDataMapper, SysDictData> implements ISysDictDataService {
  21. @Override
  22. public TableDataInfo<SysDictData> selectPageDictDataList(SysDictData dictData) {
  23. LambdaQueryWrapper<SysDictData> lqw = new LambdaQueryWrapper<SysDictData>()
  24. .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
  25. .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
  26. .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
  27. .orderByAsc(SysDictData::getDictSort);
  28. return PageUtils.buildDataInfo(page(PageUtils.buildPage(),lqw));
  29. }
  30. /**
  31. * 根据条件分页查询字典数据
  32. *
  33. * @param dictData 字典数据信息
  34. * @return 字典数据集合信息
  35. */
  36. @Override
  37. public List<SysDictData> selectDictDataList(SysDictData dictData) {
  38. return list(new LambdaQueryWrapper<SysDictData>()
  39. .eq(StrUtil.isNotBlank(dictData.getDictType()), SysDictData::getDictType, dictData.getDictType())
  40. .like(StrUtil.isNotBlank(dictData.getDictLabel()), SysDictData::getDictLabel, dictData.getDictLabel())
  41. .eq(StrUtil.isNotBlank(dictData.getStatus()), SysDictData::getStatus, dictData.getStatus())
  42. .orderByAsc(SysDictData::getDictSort));
  43. }
  44. /**
  45. * 根据字典类型和字典键值查询字典数据信息
  46. *
  47. * @param dictType 字典类型
  48. * @param dictValue 字典键值
  49. * @return 字典标签
  50. */
  51. @Override
  52. public String selectDictLabel(String dictType, String dictValue) {
  53. return getOne(new LambdaQueryWrapper<SysDictData>()
  54. .select(SysDictData::getDictLabel)
  55. .eq(SysDictData::getDictType, dictType)
  56. .eq(SysDictData::getDictValue, dictValue))
  57. .getDictLabel();
  58. }
  59. /**
  60. * 根据字典数据ID查询信息
  61. *
  62. * @param dictCode 字典数据ID
  63. * @return 字典数据
  64. */
  65. @Override
  66. public SysDictData selectDictDataById(Long dictCode) {
  67. return getById(dictCode);
  68. }
  69. /**
  70. * 批量删除字典数据信息
  71. *
  72. * @param dictCodes 需要删除的字典数据ID
  73. * @return 结果
  74. */
  75. @Override
  76. public int deleteDictDataByIds(Long[] dictCodes) {
  77. int row = baseMapper.deleteBatchIds(Arrays.asList(dictCodes));
  78. if (row > 0) {
  79. DictUtils.clearDictCache();
  80. }
  81. return row;
  82. }
  83. /**
  84. * 新增保存字典数据信息
  85. *
  86. * @param dictData 字典数据信息
  87. * @return 结果
  88. */
  89. @Override
  90. public int insertDictData(SysDictData dictData) {
  91. int row = baseMapper.insert(dictData);
  92. if (row > 0) {
  93. DictUtils.clearDictCache();
  94. }
  95. return row;
  96. }
  97. /**
  98. * 修改保存字典数据信息
  99. *
  100. * @param dictData 字典数据信息
  101. * @return 结果
  102. */
  103. @Override
  104. public int updateDictData(SysDictData dictData) {
  105. int row = baseMapper.updateById(dictData);
  106. if (row > 0) {
  107. DictUtils.clearDictCache();
  108. }
  109. return row;
  110. }
  111. }