base_from_smm_classify.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package models
  2. import (
  3. "eta_gn/eta_index_lib/global"
  4. "eta_gn/eta_index_lib/utils"
  5. "strconv"
  6. "time"
  7. )
  8. type BaseFromSmmClassify struct {
  9. ClassifyId int `gorm:"column:classify_id;primaryKey"`
  10. ClassifyName string `description:"分类名称"`
  11. ParentId int `description:"父级id"`
  12. SysUserId int `description:"创建人id"`
  13. SysUserRealName string `description:"创建人姓名"`
  14. Level int `description:"层级"`
  15. Sort int `description:"排序字段,越小越靠前,默认值:10"`
  16. ModifyTime time.Time `description:"修改时间"`
  17. CreateTime time.Time `description:"创建时间"`
  18. }
  19. func (m *BaseFromSmmClassify) TableName() string {
  20. return "base_from_smm_classify"
  21. }
  22. func AddSmmClassify(item *BaseFromSmmClassify) (lastId int64, err error) {
  23. //o := orm.NewOrm()
  24. //lastId, err = o.Insert(item)
  25. err = global.DEFAULT_DmSQL.Create(item).Error
  26. return
  27. }
  28. type AddSmmClassifyReq struct {
  29. ClassifyName string `description:"分类名称"`
  30. ParentId int `description:"父级id,第一级传0"`
  31. Level int `description:"层级,第一级传0,其余传上一级的层级"`
  32. SysUserId int `description:"操作人id"`
  33. SysUserRealName string `description:"操作人真实名称"`
  34. }
  35. // 判断分类名称是否存在
  36. func GetSmmClassify(classifyName string, parentId int) (item *BaseFromSmmClassify, err error) {
  37. //o := orm.NewOrm()
  38. sql := `SELECT * FROM base_from_smm_classify WHERE parent_id=? AND classify_name=? `
  39. //err = o.Raw(sql, parentId, classifyName).QueryRow(&item)
  40. err = global.DEFAULT_DmSQL.Raw(sql, parentId, classifyName).Scan(&item).Error
  41. return
  42. }
  43. // 添加指标分类
  44. func SaveSmmClassify(classifyName string, parentId, level int, sysUserId, sysUserName string) (classifyInfo *BaseFromSmmClassify, err error, errMsg string) {
  45. edbClassify, err := GetSmmClassify(classifyName, parentId)
  46. var isAdd bool
  47. if err != nil {
  48. if err.Error() == utils.ErrNoRow() {
  49. isAdd = true
  50. } else {
  51. errMsg = `判断名称是否已存在失败`
  52. return
  53. }
  54. }
  55. if edbClassify != nil && edbClassify.ClassifyId > 0 {
  56. classifyInfo = edbClassify
  57. return edbClassify, nil, ""
  58. } else {
  59. isAdd = true
  60. }
  61. if isAdd {
  62. sysUserIdInt, _ := strconv.Atoi(sysUserId)
  63. //获取该层级下最大的排序数
  64. maxSort, err := GetMysteelClassifyMaxSort(parentId)
  65. classifyInfo = &BaseFromSmmClassify{
  66. ClassifyName: classifyName,
  67. ParentId: parentId,
  68. CreateTime: time.Now(),
  69. ModifyTime: time.Now(),
  70. SysUserId: sysUserIdInt,
  71. SysUserRealName: sysUserName,
  72. Level: level + 1,
  73. Sort: maxSort,
  74. }
  75. classifyId, err := AddSmmClassify(classifyInfo)
  76. if err != nil {
  77. errMsg = "保存分类失败"
  78. }
  79. classifyInfo.ClassifyId = int(classifyId)
  80. }
  81. return
  82. }