chart_info.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package data_manage
  2. import (
  3. "fmt"
  4. "github.com/beego/beego/v2/client/orm"
  5. "hongze/hongze_chart_lib/utils"
  6. )
  7. // GetChartInfoRefreshData 获取图表关联的指标信息
  8. func GetChartInfoRefreshData(chartInfoId int) (baseEdbInfoArr, calculateInfoArr []*EdbInfo, err error) {
  9. o := orm.NewOrmUsingDB("data")
  10. sql := ` SELECT b.* FROM chart_edb_mapping AS a
  11. INNER JOIN edb_info AS b ON a.edb_info_id=b.edb_info_id
  12. WHERE a.chart_info_id=? `
  13. edbInfoList := make([]*EdbInfo, 0)
  14. _, err = o.Raw(sql, chartInfoId).QueryRows(&edbInfoList)
  15. if err != nil {
  16. return
  17. }
  18. for _, v := range edbInfoList {
  19. fmt.Println(v.EdbInfoId, v.EdbType)
  20. if v.EdbType == 1 {
  21. baseEdbInfoArr = append(baseEdbInfoArr, v)
  22. } else {
  23. calculateInfoArr = append(calculateInfoArr, v)
  24. newBaseEdbInfoArr, newCalculateInfoArr, err := GetChartRefreshEdbInfo(v.EdbInfoId, v.Source, 0)
  25. if err != nil {
  26. return baseEdbInfoArr, calculateInfoArr, err
  27. }
  28. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  29. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  30. }
  31. }
  32. return
  33. }
  34. func GetChartRefreshEdbInfo(edbInfoId, source, n int) (baseEdbInfoArr, calculateInfoArr []*EdbInfo, err error) {
  35. calculateList, err := GetEdbInfoCalculateMap(edbInfoId, source)
  36. if err != nil && err.Error() != utils.ErrNoRow() {
  37. return
  38. }
  39. n++
  40. for _, item := range calculateList {
  41. fmt.Println(item.EdbInfoId)
  42. if item.EdbType == 1 {
  43. baseEdbInfoArr = append(baseEdbInfoArr, item)
  44. } else {
  45. calculateInfoArr = append(calculateInfoArr, item)
  46. if n > 10 {
  47. return
  48. }
  49. newBaseEdbInfoArr, newCalculateInfoArr, _ := GetChartRefreshEdbInfo(item.EdbInfoId, item.Source, n)
  50. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  51. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  52. }
  53. }
  54. return
  55. }
  56. type ChartEdbInfoMapping struct {
  57. EdbInfoId int `description:"指标id"`
  58. SourceName string `description:"来源名称"`
  59. Source int `description:"来源id"`
  60. EdbCode string `description:"指标编码"`
  61. EdbName string `description:"指标名称"`
  62. EdbNameEn string `description:"英文指标名称"`
  63. EdbType int `description:"指标类型:1:基础指标,2:计算指标"`
  64. Frequency string `description:"频率"`
  65. FrequencyEn string `description:"英文频率"`
  66. Unit string `description:"单位"`
  67. UnitEn string `description:"英文单位"`
  68. StartDate string `description:"起始日期"`
  69. EndDate string `description:"终止日期"`
  70. ModifyTime string `description:"指标最后更新时间"`
  71. ChartEdbMappingId int `description:"图表指标id"`
  72. ChartInfoId int `description:"图表id"`
  73. MaxData float64 `description:"上限"`
  74. MinData float64 `description:"下限"`
  75. IsOrder bool `description:"true:正序,false:逆序"`
  76. IsAxis int `description:"1:左轴,0:右轴"`
  77. EdbInfoType int `description:"1:标准指标,0:领先指标"`
  78. EdbInfoCategoryType int `description:"0:普通指标,1:预测指标"`
  79. LeadValue int `description:"领先值"`
  80. LeadUnit string `description:"领先单位"`
  81. LeadUnitEn string `description:"领先英文单位"`
  82. ChartStyle string `description:"图表类型"`
  83. ChartColor string `description:"颜色"`
  84. PredictChartColor string `description:"预测数据的颜色"`
  85. ChartWidth float64 `description:"线条大小"`
  86. ChartType int `description:"生成样式:1:曲线图,2:季节性图,3:面积图,4:柱状图,5:散点图,6:组合图"`
  87. LatestDate string `description:"数据最新日期"`
  88. LatestValue float64 `description:"数据最新值"`
  89. UniqueCode string `description:"指标唯一编码"`
  90. MinValue float64 `json:"-" description:"最小值"`
  91. MaxValue float64 `json:"-" description:"最大值"`
  92. DataList interface{}
  93. }
  94. func GetChartEdbMappingList(chartInfoId int) (list []*ChartEdbInfoMapping, err error) {
  95. o := orm.NewOrmUsingDB("data")
  96. sql := ` SELECT a.*,b.source_name,b.source,b.edb_code,b.edb_name,b.edb_name_en,b.frequency,b.unit,b.unit_en,b.start_date,b.end_date,b.modify_time,b.latest_date,b.latest_value,b.unique_code,b.edb_info_type AS edb_info_category_type
  97. FROM chart_edb_mapping AS a
  98. INNER JOIN edb_info AS b ON a.edb_info_id=b.edb_info_id
  99. WHERE chart_info_id=?
  100. ORDER BY chart_edb_mapping_id ASC `
  101. _, err = o.Raw(sql, chartInfoId).QueryRows(&list)
  102. return
  103. }