edb_info_update_log.go 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. package data_stat
  2. import (
  3. "eta_gn/eta_api/global"
  4. "github.com/rdlucklib/rdluck_tools/paging"
  5. "time"
  6. )
  7. type EdbInfoUpdateLog struct {
  8. Id uint64 `gorm:"primaryKey;unique;column:id;type:bigint(20) unsigned;not null"` // 自增id
  9. EdbInfoId int `gorm:"column:edb_info_id;type:int(11);not null"` // 指标id
  10. SourceName string `gorm:"column:source_name;type:varchar(100)"` // 来源名称
  11. 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:钢联
  12. EdbCode string `gorm:"column:edb_code;type:varchar(255);not null;default:''"` // 指标编码
  13. EdbName string `gorm:"column:edb_name;type:varchar(255);default:''"` // 指标名称
  14. EdbNameSource string `gorm:"column:edb_name_source;type:varchar(255);default:''"` // 指标名称_来源
  15. Frequency string `gorm:"column:frequency;type:varchar(20);default:''"` // 频度
  16. Unit string `gorm:"column:unit;type:varchar(20);default:''"` // 单位
  17. StartDate string `gorm:"column:start_date;type:date"` // 更新开始日期
  18. EndDate string `gorm:"column:end_date;type:date"` // 更新结束日期
  19. SysUserId int `gorm:"column:sys_user_id;type:int(11)"` // 创建人
  20. SysUserRealName string `gorm:"column:sys_user_real_name;type:varchar(100)"` // 创建人姓名
  21. UpdateSysUserId int `gorm:"column:update_sys_user_id;type:int(11)"` // 变更人
  22. UpdateSysUserRealName string `gorm:"column:update_sys_user_real_name;type:varchar(100)"` // 变更人姓名
  23. EdbCreateTime time.Time `gorm:"column:edb_create_time;type:datetime"` // 指标创建时间
  24. EdbModifyTime time.Time `gorm:"column:edb_modify_time;type:datetime"` // 指标修改时间
  25. UniqueCode string `gorm:"column:unique_code;type:varchar(50);default:''"` // 唯一编码
  26. LatestDate string `gorm:"column:latest_date;type:date"` // 数据最新日期
  27. LatestValue float64 `gorm:"column:latest_value;type:double"` // 数据最新值
  28. TerminalCode string `gorm:"column:terminal_code;type:varchar(255);default:''"` // 终端编码,用于配置在机器上
  29. CreateTime time.Time `gorm:"index:create_time_idx;column:create_time;type:datetime"` // 创建时间,即指标刷新/更新操作时间点
  30. DataUpdateTime string `gorm:"column:data_update_time;type:datetime"` // 最近一次数据发生变化的时间
  31. ErDataUpdateDate string `gorm:"column:er_data_update_date;type:date"` // 本次更新,数据发生变化的最早日期
  32. UpdateResult int `gorm:"column:update_result;type:int(11)"` // 本次刷新操作结果:1成功,2失败
  33. UpdateFailedReason string `gorm:"column:update_failed_reason;type:varchar(255)"` // 刷新失败原因
  34. DataUpdateResult int `gorm:"column:data_update_result;type:int(11);not null;default:0"` // 数据更新结果:1成功,2失败,
  35. DataUpdateFailedReason string `gorm:"column:data_update_failed_reason;type:varchar(255)"` // 数据未正常更新原因,
  36. IsSourceRefresh int `gorm:"column:is_source_refresh;type:int(11);not null;default:0"` // 是否为终端刷新到数据源的刷新操作:0否,1是
  37. UpdateType int `gorm:"column:update_type;type:tinyint(4);not null;default:0"` // 变更类型,0:数据明细变更,1:基础信息变更, 2:新增指标
  38. }
  39. type EdbInfoUpdateLogItem struct {
  40. Id uint64 `orm:"column(id);pk"`
  41. EdbInfoId int `description:"指标ID"`
  42. SourceName string `description:"来源名称"`
  43. Source int `description:"来源id"`
  44. EdbCode string `description:"指标编码"`
  45. EdbName string `description:"指标名称"`
  46. EdbNameSource string `description:"指标名称来源"`
  47. Frequency string `description:"频率"`
  48. Unit string `description:"单位"`
  49. StartDate string `description:"起始日期"`
  50. EndDate string `description:"终止日期"`
  51. SysUserId int `description:"创建人ID"`
  52. SysUserRealName string `description:"创建人姓名"`
  53. UpdateSysUserId int `description:"变更人ID"`
  54. UpdateSysUserRealName string `description:"变更人姓名"`
  55. CreateTime string
  56. UniqueCode string `description:"指标唯一编码"`
  57. LatestDate string `description:"数据最新日期"`
  58. LatestValue float64 `description:"数据最新值"`
  59. TerminalCode string `description:"终端编码,用于配置在机器上"`
  60. DataUpdateTime string `description:"最近一次数据发生变化的时间"`
  61. ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"`
  62. UpdateType int `description:"变更类型,0:数据明细变更,1:基础信息变更, 2:新增指标"`
  63. }
  64. func AddEdbUpdateLog(item *EdbInfoUpdateLog) (lastId int64, err error) {
  65. err = global.DmSQL["data"].Create(item).Error
  66. lastId = int64(item.Id)
  67. return
  68. }
  69. type GetEdbUpdateLogResp struct {
  70. List []*EdbInfoUpdateLogItem
  71. Paging *paging.PagingItem
  72. }
  73. func GetEdbUpdateLogByCondition(condition string, pars []interface{}, orderStr string, pageSize, startSize int) (item []*EdbInfoUpdateLog, err error) {
  74. sql := ` SELECT * FROM edb_info_update_log WHERE 1=1 `
  75. if condition != "" {
  76. sql += condition
  77. }
  78. if orderStr != "" {
  79. sql += orderStr
  80. } else {
  81. sql += ` ORDER BY create_time DESC, id DESC `
  82. }
  83. sql += ` LIMIT ?,? `
  84. pars = append(pars, startSize)
  85. pars = append(pars, pageSize)
  86. err = global.DmSQL["data"].Raw(sql, pars...).Find(&item).Error
  87. return
  88. }
  89. // GetEdbUpdateLogCount
  90. func GetEdbUpdateLogCount(condition string, pars []interface{}) (count int, err error) {
  91. sql := ` SELECT count(*) FROM edb_info_update_log WHERE 1=1 `
  92. if condition != "" {
  93. sql += condition
  94. }
  95. err = global.DmSQL["data"].Raw(sql, pars...).Scan(&count).Error
  96. return
  97. }