edb_source_stat.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. package data_stat
  2. import (
  3. "eta_gn/eta_index_lib/global"
  4. "github.com/beego/beego/v2/client/orm"
  5. "time"
  6. )
  7. type EdbSourceStat struct {
  8. Id int `gorm:"primaryKey;autoIncrement;column:id" description:"ID"`
  9. SourceName string `gorm:"column:source_name" description:"来源名称"`
  10. Source int `gorm:"column:source" description:"来源id"`
  11. TerminalCode string `gorm:"column:terminal_code" description:"终端编码,用于配置在机器上"`
  12. EdbNum int `gorm:"column:edb_num" description:"指标总数"`
  13. EdbNewNum int `gorm:"column:edb_new_num" description:"今日新增指标数"`
  14. EdbDelNum int `gorm:"column:edb_del_num" description:"今日删除指标数"`
  15. NeedRefreshNum int `gorm:"column:need_refresh_num" description:"今日需刷新指标"`
  16. HasRefreshNum int `gorm:"column:has_refresh_num" description:"今日发起刷新任务指标数"`
  17. UpdateSuccessNum int `gorm:"column:update_success_num" description:"今日已更新成功指标数"`
  18. UpdateFailedNum int `gorm:"column:update_failed_num" description:"今日已更新失败指标数"`
  19. RefreshSuccessNum int `gorm:"column:refresh_success_num" description:"今日已刷新成功指标数"`
  20. RefreshFailedNum int `gorm:"column:refresh_failed_num" description:"今日已刷新失败指标数"`
  21. CreateTime time.Time `gorm:"column:create_time" description:"创建时间"`
  22. ModifyTime time.Time `gorm:"column:modify_time" description:"修改时间"`
  23. }
  24. func GetEdbSourceStatByCondition(condition string, pars []interface{}) (item []*EdbSourceStat, err error) {
  25. sql := ` SELECT * FROM edb_source_stat WHERE 1=1 `
  26. if condition != "" {
  27. sql += condition
  28. }
  29. err = global.DEFAULT_DmSQL.Raw(sql, pars...).Scan(&item).Error
  30. return
  31. }
  32. func (r *EdbSourceStat) Add(list []*EdbSourceStat) (err error) {
  33. o := orm.NewOrm()
  34. _, err = o.InsertMulti(len(list), list)
  35. return
  36. }
  37. func UpdateEdbSourceStatMulti(list []*EdbSourceStat) (err error) {
  38. o := orm.NewOrm()
  39. sql := `UPDATE edb_source_stat
  40. SET
  41. edb_num=?,
  42. edb_new_num=?,
  43. edb_del_num=?,
  44. need_refresh_num=?,
  45. has_refresh_num=?,
  46. update_success_num=?,
  47. update_failed_num=?,
  48. refresh_success_num=?,
  49. refresh_failed_num=?,
  50. modify_time=?
  51. WHERE
  52. id = ?`
  53. p, err := o.Raw(sql).Prepare()
  54. if err != nil {
  55. return
  56. }
  57. defer func() {
  58. _ = p.Close() // 别忘记关闭 statement
  59. }()
  60. for _, v := range list {
  61. _, err = p.Exec(v.EdbNum, v.EdbNewNum, v.EdbDelNum, v.NeedRefreshNum, v.HasRefreshNum, v.UpdateSuccessNum, v.UpdateFailedNum, v.RefreshSuccessNum, v.RefreshFailedNum, v.ModifyTime, v.Id)
  62. if err != nil {
  63. return
  64. }
  65. }
  66. return
  67. }