sa_label.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. package semantic_analysis
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "fmt"
  6. "github.com/rdlucklib/rdluck_tools/paging"
  7. "strings"
  8. "time"
  9. )
  10. type SaLabel struct {
  11. SaLabelId int `orm:"column(sa_label_id);pk" gorm:"primaryKey" description:"标签ID"`
  12. LabelName string `description:"标签名称"`
  13. SysAdminId int `description:"创建人ID"`
  14. SysAdminName string `description:"创建人名称"`
  15. CreateTime time.Time `description:"创建时间"`
  16. ModifyTime time.Time `description:"修改时间"`
  17. }
  18. var SaLabelColumns = struct {
  19. SaLabelId string
  20. LabelName string
  21. SysAdminId string
  22. SysAdminName string
  23. CreateTime string
  24. ModifyTime string
  25. }{
  26. SaLabelId: "sa_label_id",
  27. LabelName: "label_name",
  28. SysAdminId: "sys_admin_id",
  29. SysAdminName: "sys_admin_name",
  30. CreateTime: "create_time",
  31. ModifyTime: "modify_time",
  32. }
  33. func (m *SaLabel) TableName() string {
  34. return "sa_label"
  35. }
  36. func (m *SaLabel) Create() (err error) {
  37. o := global.DbMap[utils.DbNameMaster]
  38. err = o.Create(m).Error
  39. return
  40. }
  41. func (m *SaLabel) Update(cols []string) (err error) {
  42. o := global.DbMap[utils.DbNameMaster]
  43. err = o.Select(cols).Updates(m).Error
  44. return
  45. }
  46. func (m *SaLabel) Del() (err error) {
  47. o := global.DbMap[utils.DbNameMaster]
  48. sql := `DELETE FROM sa_label WHERE sa_label_id = ? LIMIT 1`
  49. err = o.Exec(sql, m.SaLabelId).Error
  50. return
  51. }
  52. func (m *SaLabel) GetItemById(id int) (err error) {
  53. o := global.DbMap[utils.DbNameMaster]
  54. sql := `SELECT * FROM sa_label WHERE sa_label_id = ? LIMIT 1`
  55. err = o.Raw(sql, id).First(&m).Error
  56. return
  57. }
  58. func (m *SaLabel) GetItemByCondition(condition string, pars []interface{}) (err error) {
  59. o := global.DbMap[utils.DbNameMaster]
  60. sql := `SELECT * FROM sa_label WHERE 1=1 `
  61. sql += condition
  62. sql += ` LIMIT 1`
  63. err = o.Raw(sql, pars...).First(&m).Error
  64. return
  65. }
  66. func (m *SaLabel) GetCountByCondition(condition string, pars []interface{}) (count int, err error) {
  67. o := global.DbMap[utils.DbNameMaster]
  68. sql := fmt.Sprintf(`SELECT COUNT(1) FROM %s WHERE 1=1 %s`, m.TableName(), condition)
  69. err = o.Raw(sql, pars...).Scan(&count).Error
  70. return
  71. }
  72. func (m *SaLabel) GetItemsByCondition(condition string, pars []interface{}, fieldArr []string, orderRule string) (items []*SaLabel, err error) {
  73. o := global.DbMap[utils.DbNameMaster]
  74. fields := strings.Join(fieldArr, ",")
  75. if len(fieldArr) == 0 {
  76. fields = `*`
  77. }
  78. order := `ORDER BY create_time DESC`
  79. if orderRule != "" {
  80. order = ` ORDER BY ` + orderRule
  81. }
  82. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  83. err = o.Raw(sql, pars...).Find(&items).Error
  84. return
  85. }
  86. func (m *SaLabel) GetPageItemsByCondition(startSize, pageSize int, condition string, pars []interface{}, fieldArr []string, orderRule string) (total int, items []*SaLabel, err error) {
  87. o := global.DbMap[utils.DbNameMaster]
  88. fields := strings.Join(fieldArr, ",")
  89. if len(fieldArr) == 0 {
  90. fields = `*`
  91. }
  92. order := `ORDER BY create_time DESC`
  93. if orderRule != "" {
  94. order = ` ORDER BY ` + orderRule
  95. }
  96. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s %s`, fields, m.TableName(), condition, order)
  97. totalSql := `SELECT COUNT(1) total FROM (` + sql + `) z`
  98. if err = o.Raw(totalSql, pars...).Scan(&total).Error; err != nil {
  99. return
  100. }
  101. sql += ` LIMIT ?,?`
  102. pars = append(pars, startSize, pageSize)
  103. err = o.Raw(sql, pars...).Find(&items).Error
  104. return
  105. }
  106. type SaLabelAddReq struct {
  107. LabelName string `description:"标签名称"`
  108. }
  109. type SaLabelEditReq struct {
  110. SaLabelId int `description:"标签ID"`
  111. SaLabelAddReq
  112. }
  113. type SaLabelDelReq struct {
  114. SaLabelId int `description:"标签ID"`
  115. }
  116. type SaLabelPageListResp struct {
  117. List []*SaLabelItem
  118. Paging *paging.PagingItem `description:"分页数据"`
  119. }
  120. type SaLabelItem struct {
  121. SaLabelId int `description:"标签ID"`
  122. LabelName string `description:"标签名称"`
  123. UserNum int `description:"引用数量"`
  124. SysAdminId int `description:"创建人ID"`
  125. SysAdminName string `description:"创建人姓名"`
  126. CreateTime string `description:"创建时间"`
  127. }