edb_info_update_stat.go 7.0 KB

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