edb_source_stat.go 2.4 KB

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