predict_edb_conf.go 5.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. package models
  2. import (
  3. "eta_gn/eta_index_lib/global"
  4. "eta_gn/eta_index_lib/utils"
  5. "time"
  6. )
  7. // AddPredictEdbInfoReq 添加预测指标请求
  8. type AddPredictEdbInfoReq struct {
  9. EdbInfoId int `description:"指标ID"`
  10. ClassifyId int `description:"分类id"`
  11. AdminId int `description:"添加人id"`
  12. AdminName string `description:"添加人名称"`
  13. SourceEdbInfoId int `description:"来源指标id"`
  14. EdbName string `description:"指标名称"`
  15. RuleList []RuleConfig `description:"配置规则列表"`
  16. MaxValue float64 `description:"最大值"`
  17. MinValue float64 `description:"最小值"`
  18. DataDateType string `description:"日期类型,枚举值:交易日、自然日"`
  19. }
  20. // RuleConfig 预测规则配置
  21. type RuleConfig struct {
  22. RuleType int `description:"预测规则,1:最新,2:固定值,3:同比,4:同差,5:环比,6:环差,7:N期移动均值,8:N期段线性外推值,9:动态环差"`
  23. Value string `description:"值/计算公式"`
  24. EmptyType int `description:"空值处理类型(0查找前后35天,1不计算,2前值填充,3后值填充,4等于0)"`
  25. MaxEmptyType int `description:"MAX、MIN公式空值处理类型(1、等于0;2、跳过空值)"`
  26. EndDate string `description:"截止日期"`
  27. EdbInfoIdArr []EdbInfoFromTag `description:"指标信息"`
  28. }
  29. // EditPredictEdbInfoReq 编辑预测指标请求
  30. type EditPredictEdbInfoReq struct {
  31. EdbInfoId int `description:"指标ID"`
  32. ClassifyId int `description:"分类id"`
  33. EdbName string `description:"指标名称"`
  34. RuleList []RuleConfig `description:"配置规则列表"`
  35. }
  36. type PredictEdbConf struct {
  37. ConfigId int `gorm:"primaryKey;autoIncrement;column:config_id" description:"规则id"`
  38. PredictEdbInfoId int `description:"预测指标id"`
  39. SourceEdbInfoId int `description:"来源指标id"`
  40. RuleType int `description:"预测规则,1:最新,2:固定值,3:同比,4:同差,5:环比,6:环差,7:N期移动均值,8:N期段线性外推值"`
  41. FixedValue float64 `description:"固定值"`
  42. Value string `description:"配置的值"`
  43. EmptyType int `description:"空值处理类型(0查找前后35天,1不计算,2前值填充,3后值填充,4等于0)"`
  44. MaxEmptyType int `description:"MAX、MIN公式空值处理类型(1、等于0;2、跳过空值)"`
  45. EndDate time.Time `description:"截止日期"`
  46. ModifyTime time.Time `description:"修改时间"`
  47. CreateTime time.Time `description:"添加时间"`
  48. }
  49. // PredictEdbConfAndData 预测规则和其对应的动态数据
  50. type PredictEdbConfAndData struct {
  51. ConfigId int `gorm:"primaryKey;autoIncrement;column:config_id" description:"规则id"`
  52. PredictEdbInfoId int `orm:"column(predict_edb_info_id)" description:"预测指标id"`
  53. SourceEdbInfoId int `description:"来源指标id"`
  54. RuleType int `description:"预测规则,1:最新,2:固定值,3:同比,4:同差,5:环比,6:环差,7:N期移动均值,8:N期段线性外推值,9:动态环差"`
  55. FixedValue float64 `description:"固定值"`
  56. Value string `description:"配置的值"`
  57. EmptyType int `description:"空值处理类型(0查找前后35天,1不计算,2前值填充,3后值填充,4等于0)"`
  58. MaxEmptyType int `description:"MAX、MIN公式空值处理类型(1、等于0;2、跳过空值)"`
  59. EndDate time.Time `description:"截止日期"`
  60. ModifyTime time.Time `description:"修改时间"`
  61. CreateTime time.Time `description:"添加时间"`
  62. DataList []*EdbInfoSearchData `description:"动态数据" gorm:"-"`
  63. }
  64. // GetPredictEdbConfListById 根据预测指标id获取预测指标配置信息列表
  65. func GetPredictEdbConfListById(edbInfoId int) (items []*PredictEdbConf, err error) {
  66. sql := ` SELECT * FROM predict_edb_conf WHERE predict_edb_info_id=? ORDER BY config_id ASC`
  67. err = global.DEFAULT_DmSQL.Raw(sql, edbInfoId).Scan(&items).Error
  68. return
  69. }
  70. // GetPredictEdbConfAndDataListById 根据预测指标id获取预测指标配置信息列表
  71. func GetPredictEdbConfAndDataListById(edbInfoId int) (items []*PredictEdbConfAndData, err error) {
  72. sql := ` SELECT * FROM predict_edb_conf WHERE predict_edb_info_id=? ORDER BY config_id ASC`
  73. err = global.DEFAULT_DmSQL.Raw(sql, edbInfoId).Scan(&items).Error
  74. return
  75. }
  76. // GetPredictEdbConfListByConfigIdList 根据预测指标id列表获取预测指标配置信息列表
  77. func GetPredictEdbConfListByConfigIdList(configIdList []int) (items []*PredictEdbConf, err error) {
  78. num := len(configIdList)
  79. if num <= 0 {
  80. return
  81. }
  82. sql := ` SELECT * FROM predict_edb_conf WHERE config_id in (` + utils.GetOrmInReplace(num) + `) ORDER BY config_id ASC`
  83. err = global.DEFAULT_DmSQL.Raw(sql, configIdList).Scan(&items).Error
  84. return
  85. }