edb_source_stat.go 2.9 KB

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