edb_info_update_stat.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package data_stat
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "github.com/rdlucklib/rdluck_tools/paging"
  6. "time"
  7. )
  8. // EdbInfoUpdateStat 指标更新/刷新 汇总表(数据源明细表)
  9. type EdbInfoUpdateStat struct {
  10. Id uint64 `orm:"column(id);pk" gorm:"primaryKey"`
  11. EdbInfoId int `description:"指标ID"`
  12. SourceName string `description:"来源名称"`
  13. Source int `description:"来源id"`
  14. EdbCode string `description:"指标编码"`
  15. EdbName string `description:"指标名称"`
  16. EdbNameSource string `description:"指标名称来源"`
  17. Frequency string `description:"频率"`
  18. Unit string `description:"单位"`
  19. StartDate string `description:"起始日期"`
  20. EndDate string `description:"终止日期"`
  21. SysUserId int `description:"创建人ID"`
  22. SysUserRealName string `description:"创建人姓名"`
  23. UniqueCode string `description:"指标唯一编码"`
  24. EdbCreateTime time.Time `description:"指标创建时间"`
  25. EdbModifyTime time.Time `description:"指标修改时间"`
  26. CreateTime time.Time
  27. UpdateTime string `description:"刷新时间"`
  28. LatestDate string `description:"数据最新日期"`
  29. LatestValue float64 `description:"数据最新值"`
  30. TerminalCode string `description:"终端编码,用于配置在机器上"`
  31. ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  32. DataUpdateResult int `description:"数据更新结果:1成功,2失败"`
  33. DataUpdateFailedReason string `description:"数据未正常更新原因"`
  34. DataUpdateTime string `description:"数据更新时间"`
  35. UpdateResult int `description:"本次刷新操作结果:1成功,2失败"`
  36. UpdateFailedReason string `description:"刷新失败原因"`
  37. ModifyTime string `description:"修改时间"`
  38. IsAdd int8 `description:"是否是当日新增的指标:1是,2否"`
  39. NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"` //todo 确认该字段
  40. HasRefresh int8 `description:"今日是否已刷新,1是,0否"`
  41. }
  42. type EdbInfoUpdateStatItem struct {
  43. Id uint64 `orm:"column(id);pk" gorm:"primaryKey"`
  44. EdbInfoId int `description:"指标ID"`
  45. SourceName string `description:"来源名称"`
  46. Source int `description:"来源id"`
  47. EdbCode string `description:"指标编码"`
  48. EdbName string `description:"指标名称"`
  49. EdbNameSource string `description:"指标名称来源"`
  50. Frequency string `description:"频率"`
  51. Unit string `description:"单位"`
  52. StartDate string `description:"起始日期"`
  53. SysUserId int `description:"创建人ID"`
  54. SysUserRealName string `description:"创建人姓名"`
  55. LatestDate string `description:"数据最新日期"`
  56. CreateTime string `description:"创建时间"`
  57. LatestValue float64 `description:"数据最新值"`
  58. TerminalCode string `description:"终端编码,用于配置在机器上"`
  59. ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  60. DataUpdateResult int `description:"数据更新结果:1成功,2失败"`
  61. DataUpdateFailedReason string `description:"数据未正常更新原因"`
  62. DataUpdateTime string `description:"数据更新时间"`
  63. UpdateResult int `description:"本次刷新操作结果:1成功,2失败"`
  64. UpdateFailedReason string `description:"刷新失败原因"`
  65. UpdateTime string `description:"刷新时间"`
  66. IsAdd int8 `description:"是否是当日新增的指标:1是,2否"`
  67. NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"`
  68. HasRefresh int8 `description:"今日是否已刷新,1是,0否"`
  69. }
  70. type EdbInfoUpdateStatItemMore struct {
  71. EdbInfoUpdateStatItem
  72. InitSourceName string `description:"初始数据源"`
  73. }
  74. type GetEdbUpdateStatResp struct {
  75. List []*EdbInfoUpdateStatItemMore
  76. Paging *paging.PagingItem
  77. }
  78. func GetEdbUpdateStatByCondition(condition string, pars []interface{}, orderStr string, pageSize, startSize int) (item []*EdbInfoUpdateStat, err error) {
  79. o := global.DbMap[utils.DbNameIndex]
  80. sql := ` SELECT * FROM edb_info_update_stat WHERE 1=1 `
  81. if condition != "" {
  82. sql += condition
  83. }
  84. if orderStr != "" {
  85. sql += orderStr
  86. } else {
  87. sql += ` ORDER BY create_time DESC, id DESC `
  88. }
  89. sql += ` LIMIT ?,? `
  90. pars = append(pars, startSize, pageSize)
  91. err = o.Raw(sql, pars...).Find(&item).Error
  92. return
  93. }
  94. // GetEdbUpdateStatCount
  95. func GetEdbUpdateStatCount(condition string, pars []interface{}) (count int, err error) {
  96. o := global.DbMap[utils.DbNameIndex]
  97. sql := ` SELECT count(*) FROM edb_info_update_stat WHERE 1=1 `
  98. if condition != "" {
  99. sql += condition
  100. }
  101. err = o.Raw(sql, pars...).Scan(&count).Error
  102. return
  103. }
  104. type EdbUpdateFailedList struct {
  105. TerminalCode string `description:"终端编码,用于配置在机器上"`
  106. SourceUpdateFailedReason string `description:"从终端刷新到数据源的数据未正常刷新原因"`
  107. Frequency string `description:"频率"`
  108. SourceUpdateResult int `description:"从终端刷新到数据源的刷新结果:1成功,2失败"`
  109. Num int
  110. }
  111. type GetEdbUpdateFailedResp struct {
  112. List []*EdbUpdateFailedList
  113. Name string `description:"终端名称"`
  114. TerminalCode string `description:"终端编码,用于配置在机器上"`
  115. DirPath string `description:"终端存放的文件夹路径"`
  116. UpdateSuccessNum int `description:"今日已更新成功指标数"`
  117. UpdateFailedNum int `description:"今日已更新失败指标数"`
  118. }
  119. func GetEdbUpdateStatFailedGroupByCondition(condition string, pars []interface{}) (item []*EdbUpdateFailedList, err error) {
  120. o := global.DbMap[utils.DbNameIndex]
  121. sql := `SELECT
  122. terminal_code,
  123. data_update_result as source_update_result,
  124. frequency,
  125. data_update_failed_reason as source_update_failed_reason,
  126. count(*) as num
  127. FROM
  128. edb_info_update_stat
  129. WHERE
  130. data_update_result != 0`
  131. if condition != "" {
  132. sql += condition
  133. }
  134. sql += ` GROUP BY
  135. data_update_result,
  136. frequency,
  137. data_update_failed_reason
  138. ORDER BY count(*) desc`
  139. err = o.Raw(sql, pars...).Find(&item).Error
  140. return
  141. }