sys_dict_data.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. package service
  2. import (
  3. "dashoo.cn/micro/app/common/global"
  4. comModel "dashoo.cn/micro/app/common/model"
  5. comService "dashoo.cn/micro/app/common/service"
  6. "dashoo.cn/micro/app/dao"
  7. "dashoo.cn/micro/app/model"
  8. "database/sql"
  9. "github.com/gogf/gf/errors/gerror"
  10. "github.com/gogf/gf/frame/g"
  11. "github.com/gogf/gf/text/gstr"
  12. "github.com/gogf/gf/util/gconv"
  13. )
  14. type sysDictData struct{}
  15. var SysDictData = new(sysDictData)
  16. func (s sysDictData) DictDataList(req *model.SelectDictPageReq) (total, page int, list []*model.SysDictData, err error) {
  17. d := dao.SysDictData.Ctx(req.Ctx)
  18. if req != nil {
  19. if req.DictLabel != "" {
  20. d = d.Where(dao.SysDictData.Columns.DictLabel+" like ?", "%"+req.DictLabel+"%")
  21. }
  22. if req.Status != "" {
  23. d = d.Where(dao.SysDictData.Columns.Status+" = ", gconv.Int(req.Status))
  24. }
  25. if req.DictType != "" {
  26. d = d.Where(dao.SysDictData.Columns.DictType+" = ?", req.DictType)
  27. }
  28. total, err = d.Count()
  29. if err != nil {
  30. g.Log().Error(err)
  31. err = gerror.New("获取总行数失败")
  32. return
  33. }
  34. if req.PageNum == 0 {
  35. req.PageNum = 1
  36. }
  37. }
  38. page = req.PageNum
  39. if req.PageSize == 0 {
  40. req.PageSize = comModel.PageSize
  41. }
  42. list, err = d.Page(page, req.PageSize).Order(dao.SysDictData.Columns.DictSort + " asc," +
  43. dao.SysDictData.Columns.DictCode + " asc").All()
  44. if err != nil {
  45. g.Log().Error(err)
  46. err = gerror.New("获取数据失败")
  47. return
  48. }
  49. return
  50. }
  51. // GetDictWithDataByType 通过字典键类型获取选项
  52. func (s sysDictData) GetDictWithDataByType(req *model.GetDictReq) (dict *model.DictRes, err error) {
  53. cache := comService.Cache.New()
  54. cacheKey := global.SysDict + "_" + req.DictType
  55. //从缓存获取
  56. iDict := cache.Get(cacheKey)
  57. if iDict != nil {
  58. err = gconv.Struct(iDict, &dict)
  59. if err != nil {
  60. return
  61. }
  62. } else {
  63. //从数据库获取
  64. dict = &model.DictRes{}
  65. //获取类型数据
  66. err = dao.SysDictType.Ctx(req.Ctx).Where(dao.SysDictType.Columns.DictType, req.DictType).
  67. And(dao.SysDictType.Columns.Status, 1).Fields(model.DictTypeRes{}).Scan(&dict.Info)
  68. if err != nil {
  69. g.Log().Error(err)
  70. err = gerror.New("获取字典类型失败")
  71. }
  72. err = dao.SysDictData.Ctx(req.Ctx).Fields(model.DictDataRes{}).
  73. Where(dao.SysDictData.Columns.DictType, req.DictType).
  74. Order(dao.SysDictData.Columns.DictSort + " asc," +
  75. dao.SysDictData.Columns.DictCode + " asc").
  76. Scan(&dict.Values)
  77. if err != nil {
  78. g.Log().Error(err)
  79. err = gerror.New("获取字典数据失败")
  80. }
  81. //缓存菜单
  82. if dict.Info != nil && dict.Values != nil {
  83. cache.Set(cacheKey, dict, 0, global.SysDictTag)
  84. }
  85. }
  86. //设置给定的默认值
  87. for _, v := range dict.Values {
  88. if req.DefaultValue != "" {
  89. if gstr.Equal(req.DefaultValue, v.DictValue) {
  90. v.IsDefault = 1
  91. } else {
  92. v.IsDefault = 0
  93. }
  94. }
  95. }
  96. return
  97. }
  98. // CheckDictTypeUniqueAll 检查字典类型是否唯一
  99. func (s *sysDictData) CheckDictTypeUniqueAll(dictType string) bool {
  100. dict, err := dao.SysDictData.FindOne(dao.SysDictData.Columns.DictType+"=?", dictType)
  101. if err != nil {
  102. g.Log().Error(err)
  103. return false
  104. }
  105. if dict != nil {
  106. return false
  107. }
  108. return true
  109. }
  110. // AddSave 添加保存字典数据
  111. func (s *sysDictData) AddSave(req *model.DictDataAddReq) (id int64, err error) {
  112. var res sql.Result
  113. res, err = dao.SysDictData.Data(req).Insert()
  114. if err != nil {
  115. g.Log().Error(err)
  116. err = gerror.New("添加字典数据失败")
  117. return
  118. }
  119. id, err = res.LastInsertId()
  120. return
  121. }
  122. // GetDictDataById 通过字典数据id获取字典数据
  123. func (s sysDictData) GetDictDataById(id int) (data *model.SysDictData, err error) {
  124. data, err = dao.SysDictData.FindOne(dao.SysDictData.Columns.DictCode, id)
  125. if err != nil {
  126. g.Log().Error(err)
  127. err = gerror.New("获取字典数据失败")
  128. return
  129. }
  130. if data == nil {
  131. err = gerror.New("获取字典数据失败")
  132. }
  133. return
  134. }
  135. // EditSaveData 修改字典数据
  136. func (s sysDictData) EditSaveData(req *model.EditDictDataReq) (err error) {
  137. _, err = dao.SysDictData.FieldsEx(dao.SysDictData.Columns.DictCode, dao.SysDictData.Columns.CreatedBy).
  138. WherePri(req.DictCode).Update(req)
  139. return
  140. }
  141. // DeleteDictDataByIds 删除字典数据
  142. func (s sysDictData) DeleteDictDataByIds(ids []int) error {
  143. _, err := dao.SysDictData.Where(dao.SysDictData.Columns.DictCode+" in(?)", ids).Delete()
  144. if err != nil {
  145. g.Log().Error(err)
  146. return gerror.New("删除失败")
  147. }
  148. return nil
  149. }