chart_variety_mapping.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package cross_variety
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "time"
  6. )
  7. // ChartVarietyMapping
  8. // @Description: 图表与品种的关系表
  9. type ChartVarietyMapping struct {
  10. Id int `orm:"column(id);pk" gorm:"primaryKey" `
  11. ChartInfoId int `description:"图表id"`
  12. ChartVarietyId int `description:"品种id"`
  13. ModifyTime time.Time `description:"修改时间"`
  14. CreateTime time.Time `description:"创建时间"`
  15. }
  16. // GetChartVarietyMappingList
  17. // @Description: 获取图表与品种的关系列表表
  18. // @author: Roc
  19. // @datetime 2023-11-24 15:22:36
  20. // @param chartInfoId int
  21. // @return items []*ChartVarietyMapping
  22. // @return err error
  23. func GetChartVarietyMappingList(chartInfoId int) (items []*ChartVarietyMapping, err error) {
  24. o := global.DbMap[utils.DbNameIndex]
  25. sql := `SELECT * FROM chart_variety_mapping WHERE chart_info_id = ? `
  26. err = o.Raw(sql, chartInfoId).Find(&items).Error
  27. return
  28. }
  29. // GetCountChartByVarietyId
  30. // @Description: 根据品种id获取引用该标签的图表数量
  31. // @author: Roc
  32. // @datetime 2023-11-27 10:41:46
  33. // @param tagId int
  34. // @return total int64
  35. // @return err error
  36. func GetCountChartByVarietyId(varietyId int) (total int64, err error) {
  37. sql := `SELECT count(1) total FROM chart_info AS a JOIN
  38. chart_variety_mapping AS b on a.chart_info_id = b.chart_info_id
  39. WHERE b.chart_variety_id = ? `
  40. err = global.DbMap[utils.DbNameIndex].Raw(sql, varietyId).Scan(&total).Error
  41. return
  42. }
  43. // GetChartVarietyMappingListByChartInfoIdList
  44. // @Description: 根据图表id列表获取图表与品种的关系列表
  45. // @author: Roc
  46. // @datetime 2023-11-24 15:22:36
  47. // @param chartInfoId int
  48. // @return items []*ChartVarietyMapping
  49. // @return err error
  50. func GetChartVarietyMappingListByChartInfoIdList(chartInfoIdList []int) (items []*ChartVarietyMapping, err error) {
  51. num := len(chartInfoIdList)
  52. if num <= 0 {
  53. return
  54. }
  55. sql := `SELECT * FROM chart_variety_mapping WHERE chart_info_id in (` + utils.GetOrmInReplace(num) + `) `
  56. err = global.DbMap[utils.DbNameIndex].Raw(sql, chartInfoIdList).Find(&chartInfoIdList).Error
  57. return
  58. }