edb_data_base.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. package data_manage
  2. import (
  3. "fmt"
  4. "github.com/rdlucklib/rdluck_tools/orm"
  5. "hongze/hongze_chart_lib/utils"
  6. "time"
  7. )
  8. //指标数据->存储表
  9. func GetEdbDataTableName(source int) (tableName string) {
  10. switch source {
  11. case utils.DATA_SOURCE_THS:
  12. tableName = "edb_data_ths"
  13. case utils.DATA_SOURCE_WIND:
  14. tableName = "edb_data_wind"
  15. case utils.DATA_SOURCE_PB:
  16. tableName = "edb_data_pb"
  17. case utils.DATA_SOURCE_CALCULATE:
  18. tableName = "edb_data_calculate"
  19. case utils.DATA_SOURCE_CALCULATE_LJZZY:
  20. tableName = "edb_data_calculate_ljzzy"
  21. case utils.DATA_SOURCE_CALCULATE_TBZ:
  22. tableName = "edb_data_calculate_tbz"
  23. case utils.DATA_SOURCE_CALCULATE_TCZ:
  24. tableName = "edb_data_calculate_tcz"
  25. case utils.DATA_SOURCE_CALCULATE_NSZYDPJJS:
  26. tableName = "edb_data_calculate_nszydpjjs"
  27. case utils.DATA_SOURCE_MANUAL:
  28. tableName = "edb_data_manual"
  29. case utils.DATA_SOURCE_LZ:
  30. tableName = "edb_data_lz"
  31. case utils.DATA_SOURCE_YS:
  32. tableName = "edb_data_ys"
  33. case utils.DATA_SOURCE_CALCULATE_HBZ:
  34. tableName = "edb_data_calculate_hbz"
  35. case utils.DATA_SOURCE_CALCULATE_HCZ:
  36. tableName = "edb_data_calculate_hcz"
  37. case utils.DATA_SOURCE_CALCULATE_BP:
  38. tableName = "edb_data_calculate_bp"
  39. case utils.DATA_SOURCE_GL:
  40. tableName = "edb_data_gl"
  41. case utils.DATA_SOURCE_ZZ:
  42. tableName = "edb_data_zz"
  43. case utils.DATA_SOURCE_DL:
  44. tableName = "edb_data_dl"
  45. case utils.DATA_SOURCE_SH:
  46. tableName = "edb_data_sh"
  47. case utils.DATA_SOURCE_CFFEX:
  48. tableName = "edb_data_cffex"
  49. case utils.DATA_SOURCE_SHFE:
  50. tableName = "edb_data_ine"
  51. case utils.DATA_SOURCE_GIE:
  52. tableName = "edb_data_gie"
  53. case utils.DATA_SOURCE_CALCULATE_ZJPJ:
  54. tableName = "edb_data_calculate_zjpj"
  55. case utils.DATA_SOURCE_CALCULATE_TIME_SHIFT:
  56. tableName = "edb_data_calculate_time_shift"
  57. case utils.DATA_SOURCE_CALCULATE_LJZTBPJ:
  58. tableName = "edb_data_calculate_ljztbpj"
  59. case utils.DATA_SOURCE_LT:
  60. tableName = "edb_data_lt"
  61. default:
  62. tableName = ""
  63. }
  64. return
  65. }
  66. //计算指标->关联的基础指标表
  67. //func GetEdbInfoCalculateTableName(source int) (tableName string) {
  68. // switch source {
  69. // case utils.DATA_SOURCE_CALCULATE:
  70. // tableName = "edb_info_calculate"
  71. // case utils.DATA_SOURCE_CALCULATE_LJZZY:
  72. // tableName = "edb_info_calculate_ljzzy"
  73. // case utils.DATA_SOURCE_CALCULATE_TBZ:
  74. // tableName = "edb_info_calculate_tbz"
  75. // case utils.DATA_SOURCE_CALCULATE_TCZ:
  76. // tableName = "edb_info_calculate_tcz"
  77. // case utils.DATA_SOURCE_CALCULATE_NSZYDPJJS:
  78. // tableName = "edb_info_calculate_nszydpjjs"
  79. // case utils.DATA_SOURCE_CALCULATE_HBZ:
  80. // tableName = "edb_info_calculate_hbz"
  81. // case utils.DATA_SOURCE_CALCULATE_HCZ:
  82. // tableName = "edb_info_calculate_hcz"
  83. // case utils.DATA_SOURCE_CALCULATE_BP:
  84. // tableName = "edb_info_calculate_bp"
  85. // default:
  86. // tableName = ""
  87. // }
  88. // return
  89. //}
  90. type EdbDataBase struct {
  91. EdbDataId int `orm:"column(edb_data_id);pk"`
  92. EdbInfoId int
  93. EdbCode string
  94. DataTime string
  95. Value string
  96. Status int
  97. CreateTime time.Time
  98. ModifyTime time.Time
  99. DataTimestamp int64
  100. }
  101. func GetEdbDataAllByEdbCode(edbCode string, source, limit int) (items []*EdbInfoSearchData, err error) {
  102. var pars []interface{}
  103. pars = append(pars, edbCode)
  104. o := orm.NewOrm()
  105. o.Using("data")
  106. tableName := GetEdbDataTableName(source)
  107. sql := ` SELECT * FROM %s WHERE edb_code=? ORDER BY data_time DESC`
  108. if limit > 0 {
  109. sql += ` LIMIT ? `
  110. pars = append(pars, limit)
  111. }
  112. sql = fmt.Sprintf(sql, tableName)
  113. _, err = o.Raw(sql, pars).QueryRows(&items)
  114. return
  115. }
  116. func GetEdbDataBaseByCodeAndDate(source int, edbCode string, startDate string) (count int, err error) {
  117. o := orm.NewOrm()
  118. o.Using("data")
  119. tableName := GetEdbDataTableName(source)
  120. sql := ` SELECT COUNT(1) AS count FROM %s WHERE edb_code=? AND data_time=? `
  121. sql = fmt.Sprintf(sql, tableName)
  122. err = o.Raw(sql, edbCode, startDate).QueryRow(&count)
  123. return
  124. }