edb_info_update_stat.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package data_stat
  2. import (
  3. "eta_gn/eta_api/global"
  4. "github.com/rdlucklib/rdluck_tools/paging"
  5. "time"
  6. )
  7. // EdbInfoUpdateStat 指标更新/刷新 汇总表(数据源明细表)
  8. //type EdbInfoUpdateStat struct {
  9. // Id uint64 `orm:"column(id);pk"`
  10. // EdbInfoId int `description:"指标ID"`
  11. // SourceName string `description:"来源名称"`
  12. // Source int `description:"来源id"`
  13. // EdbCode string `description:"指标编码"`
  14. // EdbName string `description:"指标名称"`
  15. // EdbNameSource string `description:"指标名称来源"`
  16. // Frequency string `description:"频率"`
  17. // Unit string `description:"单位"`
  18. // StartDate string `description:"起始日期"`
  19. // EndDate string `description:"终止日期"`
  20. // SysUserId int `description:"创建人ID"`
  21. // SysUserRealName string `description:"创建人姓名"`
  22. // UniqueCode string `description:"指标唯一编码"`
  23. // EdbCreateTime time.Time `description:"指标创建时间"`
  24. // EdbModifyTime time.Time `description:"指标修改时间"`
  25. // CreateTime time.Time
  26. // UpdateTime string `description:"刷新时间"`
  27. // LatestDate string `description:"数据最新日期"`
  28. // LatestValue float64 `description:"数据最新值"`
  29. // TerminalCode string `description:"终端编码,用于配置在机器上"`
  30. // ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  31. // DataUpdateResult int `description:"数据更新结果:1成功,2失败"`
  32. // DataUpdateFailedReason string `description:"数据未正常更新原因"`
  33. // DataUpdateTime string `description:"数据更新时间"`
  34. // UpdateResult int `description:"本次刷新操作结果:1成功,2失败"`
  35. // UpdateFailedReason string `description:"刷新失败原因"`
  36. // ModifyTime string `description:"修改时间"`
  37. // IsAdd int8 `description:"是否是当日新增的指标:1是,2否"`
  38. // NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"` //todo 确认该字段
  39. // HasRefresh int8 `description:"今日是否已刷新,1是,0否"`
  40. //}
  41. type EdbInfoUpdateStat struct {
  42. Id uint64 `gorm:"primaryKey;unique;column:id;type:bigint(20) unsigned;not null"` // 自增id
  43. EdbInfoId int `gorm:"column:edb_info_id;type:int(11);not null"` // 指标id
  44. SourceName string `gorm:"column:source_name;type:varchar(100)"` // 来源名称
  45. Source int `gorm:"column:source;type:tinyint(4)"` // 来源:1:同花顺,2:wind,3:彭博,4:指标运算,5:累计值转月,6:同比值,7:同差值,8:N数值移动平均计算,9:手工指标,10:隆众,11:有色,12:环比值,13:环差值,14:变频,15:钢联
  46. EdbCode string `gorm:"column:edb_code;type:varchar(255);not null;default:''"` // 指标编码
  47. EdbName string `gorm:"column:edb_name;type:varchar(255);default:''"` // 指标名称
  48. EdbNameSource string `gorm:"column:edb_name_source;type:varchar(255);default:''"` // 指标名称_来源
  49. Frequency string `gorm:"column:frequency;type:varchar(20);default:''"` // 频度
  50. Unit string `gorm:"column:unit;type:varchar(20);default:''"` // 单位
  51. StartDate string `gorm:"column:start_date;type:date"` // 更新开始日期
  52. EndDate string `gorm:"column:end_date;type:date"` // 更新结束日期
  53. SysUserId int `gorm:"column:sys_user_id;type:int(11)"` // 创建人
  54. SysUserRealName string `gorm:"column:sys_user_real_name;type:varchar(100)"` // 创建人姓名
  55. EdbCreateTime time.Time `gorm:"column:edb_create_time;type:datetime"` // 指标创建时间
  56. EdbModifyTime time.Time `gorm:"column:edb_modify_time;type:datetime"` // 指标修改时间
  57. UniqueCode string `gorm:"column:unique_code;type:varchar(50);default:''"` // 唯一编码
  58. LatestDate string `gorm:"column:latest_date;type:date"` // 数据最新日期
  59. LatestValue float64 `gorm:"column:latest_value;type:double"` // 数据最新值
  60. TerminalCode string `gorm:"column:terminal_code;type:varchar(255);default:''"` // 终端编码,用于配置在机器上
  61. CreateTime time.Time `gorm:"index:create_time_idx;column:create_time;type:datetime"` // 创建时间
  62. ModifyTime time.Time `gorm:"column:modify_time;type:datetime"` // 修改时间
  63. UpdateTime string `gorm:"column:update_time;type:datetime"` // 刷新/修改时间
  64. DataUpdateTime string `gorm:"column:data_update_time;type:datetime"` // 当天数据发生变化的时间
  65. ErDataUpdateDate string `gorm:"column:er_data_update_date;type:date"` // 当天数据发生变化的最早日期
  66. UpdateResult int `gorm:"column:update_result;type:int(11)"` // 当天刷新结果:1成功,2失败
  67. UpdateFailedReason string `gorm:"column:update_failed_reason;type:varchar(255)"` // 当天数据未正常刷新原因
  68. IsAdd int8 `gorm:"column:is_add;type:tinyint(4);not null;default:0"` // 是否是当日新增的指标:1是,2否
  69. NeedRefresh int8 `gorm:"column:need_refresh;type:tinyint(4);not null;default:0"` // 今日是否需要刷新,1需要,0不需要
  70. HasRefresh int8 `gorm:"column:has_refresh;type:tinyint(4);not null;default:0"` // 今日是否已刷新,1是,0否
  71. DataUpdateResult int `gorm:"column:data_update_result;type:int(11);not null;default:0"` // 数据更新结果:1成功,2失败,
  72. DataUpdateFailedReason string `gorm:"column:data_update_failed_reason;type:varchar(255)"` // 数据未正常更新原因,
  73. }
  74. type EdbInfoUpdateStatItem struct {
  75. Id uint64 `orm:"column(id);pk"`
  76. EdbInfoId int `description:"指标ID"`
  77. SourceName string `description:"来源名称"`
  78. Source int `description:"来源id"`
  79. EdbCode string `description:"指标编码"`
  80. EdbName string `description:"指标名称"`
  81. EdbNameSource string `description:"指标名称来源"`
  82. Frequency string `description:"频率"`
  83. Unit string `description:"单位"`
  84. StartDate string `description:"起始日期"`
  85. SysUserId int `description:"创建人ID"`
  86. SysUserRealName string `description:"创建人姓名"`
  87. LatestDate string `description:"数据最新日期"`
  88. CreateTime string `description:"创建时间"`
  89. LatestValue float64 `description:"数据最新值"`
  90. TerminalCode string `description:"终端编码,用于配置在机器上"`
  91. ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  92. DataUpdateResult int `description:"数据更新结果:1成功,2失败"`
  93. DataUpdateFailedReason string `description:"数据未正常更新原因"`
  94. DataUpdateTime string `description:"数据更新时间"`
  95. UpdateResult int `description:"本次刷新操作结果:1成功,2失败"`
  96. UpdateFailedReason string `description:"刷新失败原因"`
  97. UpdateTime string `description:"刷新时间"`
  98. IsAdd int8 `description:"是否是当日新增的指标:1是,2否"`
  99. NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"`
  100. HasRefresh int8 `description:"今日是否已刷新,1是,0否"`
  101. }
  102. type EdbInfoUpdateStatItemMore struct {
  103. EdbInfoUpdateStatItem
  104. InitSourceName string `description:"初始数据源"`
  105. }
  106. type GetEdbUpdateStatResp struct {
  107. List []*EdbInfoUpdateStatItemMore
  108. Paging *paging.PagingItem
  109. }
  110. func GetEdbUpdateStatByCondition(condition string, pars []interface{}, orderStr string, pageSize, startSize int) (item []*EdbInfoUpdateStat, err error) {
  111. //o := orm.NewOrmUsingDB("data")
  112. sql := ` SELECT * FROM edb_info_update_stat WHERE 1=1 `
  113. if condition != "" {
  114. sql += condition
  115. }
  116. if orderStr != "" {
  117. sql += orderStr
  118. } else {
  119. sql += ` ORDER BY create_time DESC, id DESC `
  120. }
  121. sql += ` LIMIT ?,? `
  122. //_, err = o.Raw(sql, pars...).QueryRows(&item)
  123. pars = append(pars, startSize)
  124. pars = append(pars, pageSize)
  125. err = global.DmSQL["data"].Raw(sql, pars...).Find(&item).Error
  126. return
  127. }
  128. // GetEdbUpdateStatCount
  129. func GetEdbUpdateStatCount(condition string, pars []interface{}) (count int, err error) {
  130. //o := orm.NewOrmUsingDB("data")
  131. sql := ` SELECT count(*) FROM edb_info_update_stat WHERE 1=1 `
  132. if condition != "" {
  133. sql += condition
  134. }
  135. //err = o.Raw(sql, pars).QueryRow(&count)
  136. err = global.DmSQL["data"].Raw(sql, pars...).Scan(&count).Error
  137. return
  138. }
  139. type EdbUpdateFailedList struct {
  140. TerminalCode string `description:"终端编码,用于配置在机器上"`
  141. SourceUpdateFailedReason string `description:"从终端刷新到数据源的数据未正常刷新原因"`
  142. Frequency string `description:"频率"`
  143. SourceUpdateResult int `description:"从终端刷新到数据源的刷新结果:1成功,2失败"`
  144. Num int
  145. }
  146. type GetEdbUpdateFailedResp struct {
  147. List []*EdbUpdateFailedList
  148. Name string `description:"终端名称"`
  149. TerminalCode string `description:"终端编码,用于配置在机器上"`
  150. DirPath string `description:"终端存放的文件夹路径"`
  151. UpdateSuccessNum int `description:"今日已更新成功指标数"`
  152. UpdateFailedNum int `description:"今日已更新失败指标数"`
  153. }
  154. func GetEdbUpdateStatFailedGroupByCondition(condition string, pars []interface{}) (item []*EdbUpdateFailedList, err error) {
  155. //o := orm.NewOrmUsingDB("data")
  156. sql := `SELECT
  157. terminal_code,
  158. data_update_result as source_update_result,
  159. frequency,
  160. data_update_failed_reason as source_update_failed_reason,
  161. count(*) as num
  162. FROM
  163. edb_info_update_stat
  164. WHERE
  165. data_update_result != 0`
  166. if condition != "" {
  167. sql += condition
  168. }
  169. sql += ` GROUP BY
  170. data_update_result,
  171. frequency,
  172. data_update_failed_reason
  173. ORDER BY count(*) desc`
  174. //_, err = o.Raw(sql, pars).QueryRows(&item)
  175. err = global.DmSQL["data"].Raw(sql, pars...).Find(&item).Error
  176. return
  177. }