edb_data_sh.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. package data_manage
  2. //type ShData struct {
  3. // InputValue string `orm:"column(DATA_VALUE)" description:"日期"`
  4. // DataTime string `orm:"column(DATA_DATE)" description:"值"`
  5. //}
  6. //type BaseFromShDataSimple struct {
  7. // Id int `orm:"column(base_from_trade_shanghai_index_id);pk" gorm:"primaryKey"`
  8. // DealCode string
  9. // BuyCode string
  10. // SoldCode string
  11. // DataTime string
  12. // DealValue string
  13. // BuyValue string
  14. // SoldValue string
  15. //}
  16. //type BaseInfoFromSh struct {
  17. // DealName string
  18. // BuyName string
  19. // SoldName string
  20. //}
  21. //type BaseFromTradeShIndex struct {
  22. // BaseFromTradeShIndexId int `orm:"column(base_from_trade_shanghai_index_id);pk" gorm:"primaryKey"`
  23. // Rank int
  24. // DealShortName string
  25. // DealName string
  26. // DealCode string
  27. // DealValue string
  28. // DealChange int
  29. // BuyShortName string
  30. // BuyName string
  31. // BuyCode string
  32. // BuyValue string
  33. // BuyChange int
  34. // SoldShortName string
  35. // SoldName string
  36. // SoldCode string
  37. // SoldValue string
  38. // SoldChange int
  39. // Frequency string
  40. // ClassifyName string
  41. // ClassifyType string
  42. // CreateTime time.Time
  43. // ModifyTime time.Time
  44. // DataTime string
  45. //}
  46. //func GetEdbDataShMaxOrMinDate(edbCode string) (minDate, maxDate string, err error) {
  47. // o := global.DbMap[utils.DbNameIndex]
  48. // sql := ` SELECT MIN(data_time) AS minDate,MAX(data_time) AS maxDate FROM edb_data_sh WHERE edb_code=? `
  49. // err = o.Raw(sql, edbCode).Row().Scan(&minDate, &maxDate)
  50. // return
  51. //}
  52. // RefreshEdbDataBySh 刷新上期所指标数据
  53. //func RefreshEdbDataBySh(edbInfoId int, edbCode, startDate, endDate string) (err error) {
  54. // o := global.DbMap[utils.DbNameIndex]
  55. // tx := o.Begin()
  56. // if tx.Error != nil {
  57. // return tx.Error
  58. // }
  59. // defer func() {
  60. // if err != nil {
  61. // tx.Rollback()
  62. // } else {
  63. // tx.Commit()
  64. // }
  65. // }()
  66. // if err != nil {
  67. // return
  68. // }
  69. // var suffix string
  70. // if strings.Contains(edbCode, "deal") {
  71. // suffix = "deal"
  72. // } else if strings.Contains(edbCode, "buy") {
  73. // suffix = "buy"
  74. // } else if strings.Contains(edbCode, "sold") {
  75. // suffix = "sold"
  76. // }
  77. // edbInfoIdStr := strconv.Itoa(edbInfoId)
  78. // //计算数据
  79. // var condition string
  80. // var pars []interface{}
  81. //
  82. // if edbCode != "" {
  83. // if suffix == "deal" {
  84. // condition += " AND deal_code=? "
  85. // } else if suffix == "buy" {
  86. // condition += " AND buy_code=? "
  87. // } else {
  88. // condition += " AND sold_code=? "
  89. // }
  90. // pars = append(pars, edbCode)
  91. // }
  92. //
  93. // if startDate != "" {
  94. // condition += " AND data_time>=? "
  95. // pars = append(pars, startDate)
  96. // }
  97. //
  98. // if endDate != "" {
  99. // condition += " AND data_time<=? "
  100. // pars = append(pars, endDate)
  101. // }
  102. //
  103. // glDataList, err := GetShDataByTradeCode(condition, pars)
  104. //
  105. // addSql := ` INSERT INTO edb_data_sh(edb_info_id,edb_code,data_time,value,create_time,modify_time,status,data_timestamp) values `
  106. // var isAdd bool
  107. // existMap := make(map[string]string)
  108. // for _, v := range glDataList {
  109. // var value string
  110. // if suffix == "deal" {
  111. // value = v.DealValue
  112. // } else if suffix == "buy" {
  113. // value = v.BuyValue
  114. // } else {
  115. // value = v.SoldValue
  116. // }
  117. // item := v
  118. // itemValue := value
  119. // if _, ok := existMap[v.DataTime]; !ok {
  120. // count, err := GetEdbDataShByCodeAndDate(edbCode, v.DataTime)
  121. // if err != nil {
  122. // return err
  123. // }
  124. // if count <= 0 {
  125. // eDate := item.DataTime
  126. // sValue := itemValue
  127. // if sValue != "" {
  128. // dataTime, err := time.Parse(utils.FormatDate, eDate)
  129. // if err != nil {
  130. // return err
  131. // }
  132. // timestamp := dataTime.UnixNano() / 1e6
  133. // timeStr := fmt.Sprintf("%d", timestamp)
  134. // addSql += GetAddSql(edbInfoIdStr, edbCode, eDate, timeStr, sValue)
  135. // isAdd = true
  136. // }
  137. // } else {
  138. // err = ModifyEdbDataSh(int64(edbInfoId), v.DataTime, value)
  139. // if err != nil {
  140. // return err
  141. // }
  142. // }
  143. // }
  144. // existMap[v.DataTime] = value
  145. // }
  146. // if isAdd {
  147. // addSql = strings.TrimRight(addSql, ",")
  148. // err = tx.Exec(addSql, pars...).Error
  149. // if err != nil {
  150. // return err
  151. // }
  152. // }
  153. // return
  154. //}
  155. // GetBaseInfoFromShByIndexCode 获取指标信息
  156. //func GetBaseInfoFromShByIndexCode(indexCode, suffix string) (list []*BaseInfoFromSh, err error) {
  157. // o := global.DbMap[utils.DbNameIndex]
  158. // sql := `SELECT * FROM base_from_trade_shanghai_index WHERE %s_code=? `
  159. // sql = fmt.Sprintf(sql, suffix)
  160. // err = o.Raw(sql, indexCode).Find(&list).Error
  161. // return
  162. //}
  163. //func GetShDataByTradeCode(condition string, pars []interface{}) (item []*BaseFromShDataSimple, err error) {
  164. // sql := ` SELECT * FROM base_from_trade_shanghai_index WHERE 1=1 `
  165. // o := global.DbMap[utils.DbNameIndex]
  166. // if condition != "" {
  167. // sql += condition
  168. // }
  169. // sql += ` ORDER BY data_time DESC `
  170. // err = o.Raw(sql, pars).Find(&item).Error
  171. // return
  172. //}
  173. //func AddEdbDataShBySql(sqlStr string) (err error) {
  174. // o := global.DbMap[utils.DbNameIndex]
  175. // err = o.Exec(sqlStr).Error
  176. // return
  177. //}
  178. //func GetBaseFromShDataAllByIndexCode(indexCode, suffix string) (list []*BaseFromTradeShIndex, err error) {
  179. // o := global.DbMap[utils.DbNameIndex]
  180. // sql := `SELECT * FROM base_from_trade_shanghai_index WHERE %s_code=? `
  181. // sql = fmt.Sprintf(sql, suffix)
  182. // err = o.Raw(sql, indexCode).Find(&list).Error
  183. // return
  184. //}
  185. //func GetEdbDataShByCodeAndDate(edbCode string, startDate string) (count int, err error) {
  186. // o := global.DbMap[utils.DbNameIndex]
  187. // sql := ` SELECT COUNT(1) AS count FROM edb_data_sh WHERE edb_code=? AND data_time=? `
  188. // err = o.Raw(sql, edbCode, startDate).Scan(&count).Error
  189. // return
  190. //}
  191. //func ModifyEdbDataSh(edbInfoId int64, dataTime, value string) (err error) {
  192. // o := global.DbMap[utils.DbNameIndex]
  193. // sql := ` UPDATE edb_data_sh SET value=?,modify_time=NOW() WHERE edb_info_id=? AND data_time=? `
  194. // err = o.Exec(sql, value, edbInfoId, dataTime).Error
  195. // return
  196. //}