base_from_coalmine.go 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. package models
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. type BaseFromCoalmineMapping struct {
  7. BaseFromCoalmineMappingId int `orm:"column(base_from_coalmine_mapping_id);pk"`
  8. IndexName string `description:"持买单量指标名称"`
  9. IndexCode string `description:"持买单量指标编码"`
  10. CreateTime time.Time `description:"时间"`
  11. }
  12. type BaseFromCoalmineJsmIndex struct {
  13. BaseFromCoalmineJsmIndexId int `orm:"column(base_from_coalmine_jsm_index_id);pk"`
  14. IndexName string `description:"持买单量指标名称"`
  15. IndexCode string `description:"持买单量指标编码"`
  16. Exchange string `description:"样本统计类别"`
  17. DealValue string `description:"成交量"`
  18. DataTime string `description:"数据日期"`
  19. Source string `description:"来源"`
  20. Province string `description:"省份"`
  21. Description string `description:"描述"`
  22. Unit string `description:"单位"`
  23. Frequency string `description:"频率"`
  24. CreateTime time.Time `description:"插入时间"`
  25. ModifyTime time.Time `description:"修改时间"`
  26. }
  27. type BaseFromCoalmineCompanyIndex struct {
  28. BaseFromCoalmineCompanyIndexId int `orm:"column(base_from_coalmine_company_index_id);pk"`
  29. IndexName string `description:"持买单量指标名称"`
  30. IndexCode string `description:"持买单量指标编码"`
  31. DealValue string `description:"成交量"`
  32. DataTime string `description:"数据日期"`
  33. Source string `description:"来源"`
  34. Province string `description:"省份"`
  35. City string `description:"城市"`
  36. GroupName string `description:"集团名称"`
  37. Unit string `description:"单位"`
  38. Frequency string `description:"频率"`
  39. CreateTime time.Time `description:"插入时间"`
  40. ModifyTime time.Time `description:"修改时间"`
  41. }
  42. // 添加指标
  43. func AddBaseFromCoalmineMapping(item *BaseFromCoalmineMapping) (lastId int64, err error) {
  44. o := orm.NewOrm()
  45. lastId, err = o.Insert(item)
  46. return
  47. }
  48. // 查询指标
  49. func GetBaseFromCoalmineMapping() (items []*BaseFromCoalmineMapping, err error) {
  50. o := orm.NewOrm()
  51. sql := `SELECT * FROM base_from_coalmine_mapping`
  52. _, err = o.Raw(sql).QueryRows(&items)
  53. return
  54. }
  55. // 查询数据
  56. func GetBaseFromCoalmineIndex() (items []*BaseFromCoalmineJsmIndex, err error) {
  57. o := orm.NewOrm()
  58. sql := `SELECT * FROM base_from_coalmine_jsm_index`
  59. _, err = o.Raw(sql).QueryRows(&items)
  60. return
  61. }
  62. func UpdateBaseFromCoalmineIndex(item *BaseFromCoalmineJsmIndex) (err error) {
  63. o := orm.NewOrm()
  64. sql := `UPDATE base_from_coalmine_jsm_index SET deal_value=? WHERE index_name=? AND data_time = ?`
  65. _, err = o.Raw(sql, item.DealValue, item.IndexName, item.DataTime).Exec()
  66. return
  67. }
  68. // 添加数据
  69. func AddBaseFromCoalmineIndex(item *BaseFromCoalmineJsmIndex) (lastId int64, err error) {
  70. o := orm.NewOrm()
  71. lastId, err = o.Insert(item)
  72. return
  73. }
  74. // 添加公司指标
  75. func AddBaseFromCoalmineCompanyIndex(item *BaseFromCoalmineCompanyIndex) (lastId int64, err error) {
  76. o := orm.NewOrm()
  77. lastId, err = o.Insert(item)
  78. return
  79. }
  80. // 查询公司指标
  81. func GetBaseFromCoalmineCompanyIndex() (items []*BaseFromCoalmineCompanyIndex, err error) {
  82. o := orm.NewOrm()
  83. sql := `SELECT * FROM base_from_coalmine_company_index`
  84. _, err = o.Raw(sql).QueryRows(&items)
  85. return
  86. }
  87. func UpdateBaseFromCoalmineCompanyIndex(item *BaseFromCoalmineCompanyIndex) (err error) {
  88. o := orm.NewOrm()
  89. sql := `UPDATE base_from_coalmine_company_index SET deal_value=? WHERE index_name=? AND data_time = ?`
  90. _, err = o.Raw(sql, item.DealValue, item.IndexName, item.DataTime).Exec()
  91. return
  92. }
  93. func (m *BaseFromCoalmineMapping) GetMaxAndMinDateByIndexCode(indexCode string) (item *EdbInfoMaxAndMinInfo, err error) {
  94. o := orm.NewOrm()
  95. sql := ` SELECT MIN(data_time) AS min_date,MAX(data_time) AS max_date,MIN(value) AS min_value,MAX(value) AS max_value FROM base_from_sci99_data WHERE index_code=? `
  96. err = o.Raw(sql, indexCode).QueryRow(&item)
  97. if err != nil {
  98. return
  99. }
  100. // 获取最新值
  101. var latest_value float64
  102. sql = ` SELECT value AS latest_value FROM base_from_sci99_data WHERE index_code=? ORDER BY data_time DESC LIMIT 1 `
  103. err = o.Raw(sql, indexCode).QueryRow(&latest_value)
  104. if err != nil {
  105. return
  106. }
  107. item.LatestValue = latest_value
  108. return
  109. }
  110. func (m *BaseFromCoalmineMapping) ModifyIndexMaxAndMinDate(indexCode string, item *EdbInfoMaxAndMinInfo) (err error) {
  111. o := orm.NewOrm()
  112. sql := ` UPDATE base_from_sci99_index SET start_date=?,end_date=?,latest_value=?,modify_time=NOW() WHERE index_code=? `
  113. _, err = o.Raw(sql, item.MinDate, item.MaxDate, item.LatestValue, indexCode).Exec()
  114. return
  115. }
  116. type CoalMineDataReq struct {
  117. SheetData []SheetData
  118. }
  119. type SheetData struct {
  120. Name string
  121. Rows []Row
  122. Cols []*Col
  123. MaxRow int
  124. MaxCol int
  125. Hidden bool
  126. Selected bool
  127. }
  128. type Row struct {
  129. Cells []Cell
  130. Hidden bool
  131. Height float64
  132. OutlineLevel uint8
  133. isCustom bool
  134. }
  135. type Col struct {
  136. Min int
  137. Max int
  138. Hidden bool
  139. Width float64
  140. Collapsed bool
  141. OutlineLevel uint8
  142. numFmt string
  143. }
  144. type Cell struct {
  145. Value string
  146. }