trade_analysis.go 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. package trade_analysis
  2. import (
  3. "eta/eta_api/global"
  4. "eta/eta_api/utils"
  5. "fmt"
  6. "strings"
  7. "time"
  8. )
  9. const (
  10. TradeDataTypeNull = 0 // 无值
  11. TradeDataTypeOrigin = 1 // 原始值
  12. TradeDataTypeCalculate = 2 // 推算值
  13. WarehouseBuyChartType = 1 // 多单图
  14. WarehouseSoldChartType = 2 // 空单图
  15. WarehousePureBuyChartType = 3 // 净多单图
  16. WarehouseDefaultUnit = "手"
  17. WarehouseDefaultFrequency = "日度"
  18. GuangZhouTopCompanyAliasName = "日成交持仓排名" // 广期所TOP20对应的公司名称
  19. GuangZhouSeatNameBuy = "持买单量" // 广期所指标名称中的多单名称
  20. GuangZhouSeatNameSold = "持卖单量" // 广期所指标名称中的空单名称
  21. GuangZhouTopSeatNameBuy = "持买单量总计" // 广期所指标名称中的TOP20多单名称
  22. GuangZhouTopSeatNameSold = "持卖单量总计" // 广期所指标名称中的TOP20空单名称
  23. GuangZhouTopSeatNameDeal = "成交量总计" // 广期所指标名称中的TOP20成交量名称
  24. )
  25. const (
  26. TradeExchangeDalian = "dalian"
  27. TradeExchangeZhengzhou = "zhengzhou"
  28. TradeExchangeGuangzhou = "guangzhou"
  29. )
  30. var WarehouseTypeSuffixNames = map[int]string{
  31. WarehouseBuyChartType: "席位多单",
  32. WarehouseSoldChartType: "席位空单",
  33. WarehousePureBuyChartType: "席位净多单",
  34. }
  35. // GuangzhouSeatNameValType 广期所数据名称对应的席位方向
  36. var GuangzhouSeatNameValType = map[string]int{
  37. GuangZhouSeatNameBuy: 1,
  38. GuangZhouSeatNameSold: 2,
  39. GuangZhouTopSeatNameBuy: 1,
  40. GuangZhouTopSeatNameSold: 2,
  41. GuangZhouTopSeatNameDeal: 3,
  42. }
  43. // 合约查询方式
  44. var (
  45. ContractQueryTypeTop = 1 // 主力合约
  46. ContractQueryTypeTop2 = 2 // 成交量前2
  47. ContractQueryTypeTop3 = 3 // 成交量前3
  48. ContractQueryTypeAll = 4 // 所有合约(多个)
  49. ContractQueryTypeTotal = 5 // 合约加总(1个)
  50. )
  51. // 合约方向
  52. var (
  53. ContractPositionBuy = 1 // 多单
  54. ContractPositionSold = 2 // 空单
  55. ContractPositionPureBuy = 3 // 净多单
  56. )
  57. // TradePositionTop 持仓榜单
  58. type TradePositionTop struct {
  59. Id uint64 `gorm:"primaryKey;column:id" json:"id"`
  60. ClassifyName string `gorm:"column:classify_name" json:"classify_name"` //分类名称
  61. ClassifyType string `gorm:"column:classify_type" json:"classify_type"` //分类名称下的类型
  62. DealShortName string `gorm:"column:deal_short_name" json:"deal_short_name"` //成交量公司简称
  63. DealValue int `gorm:"column:deal_value" json:"deal_value"` //成交量
  64. DealChange int `gorm:"column:deal_change" json:"deal_change"` //成交变化量
  65. DataTime time.Time `gorm:"column:data_time" json:"data_time"` //数据日期
  66. CreateTime time.Time `gorm:"column:create_time" json:"create_time"` //插入时间
  67. ModifyTime time.Time `gorm:"column:modify_time" json:"modify_time"` //修改时间
  68. DealType int `gorm:"column:deal_type" json:"deal_type"` //交易类型:1多单,2空单,3净多单,4净空单
  69. SourceType int `gorm:"column:source_type" json:"source_type"` //数据来源,0是原始数据的值,1是由T+1日推算出的值,2是由T日的榜单数据推算出的值
  70. Rank int `gorm:"column:rank" json:"rank"` //排名
  71. }
  72. type TradeClassifyNameList struct {
  73. Exchange string `description:"交易所"`
  74. ExchangeEn string `description:"交易所英文"`
  75. Sort int `description:"排序字段" `
  76. Num int `description:"品种数量"`
  77. DataTime string `description:"最新更新时间"`
  78. CurrDate string `description:"当前日期"`
  79. Items []TradeClassifyNameListItem `description:"子类"`
  80. }
  81. type TradeClassifyNameListSort []TradeClassifyNameList
  82. func (v TradeClassifyNameListSort) Len() int {
  83. return len(v)
  84. }
  85. func (v TradeClassifyNameListSort) Swap(i, j int) {
  86. v[i], v[j] = v[j], v[i]
  87. }
  88. func (v TradeClassifyNameListSort) Less(i, j int) bool {
  89. return v[i].Sort < v[j].Sort
  90. }
  91. type TradeClassifyNameListItemSort []TradeClassifyNameListItem
  92. func (v TradeClassifyNameListItemSort) Len() int {
  93. return len(v)
  94. }
  95. func (v TradeClassifyNameListItemSort) Swap(i, j int) {
  96. v[i], v[j] = v[j], v[i]
  97. }
  98. func (v TradeClassifyNameListItemSort) Less(i, j int) bool {
  99. return v[i].ClassifyName < v[j].ClassifyName
  100. }
  101. type TradeClassifyNameListItem struct {
  102. ClassifyName string `description:"交易分类"`
  103. Items []TradeClassifyNameListItemItem `description:"合约代码"`
  104. }
  105. type TradeClassifyNameListItemItemSort []TradeClassifyNameListItemItem
  106. func (v TradeClassifyNameListItemItemSort) Len() int {
  107. return len(v)
  108. }
  109. func (v TradeClassifyNameListItemItemSort) Swap(i, j int) {
  110. v[i], v[j] = v[j], v[i]
  111. }
  112. func (v TradeClassifyNameListItemItemSort) Less(i, j int) bool {
  113. return v[i].ClassifyType < v[j].ClassifyType
  114. }
  115. type TradeClassifyNameListItemItem struct {
  116. ClassifyType string `description:"分类名称下的类型"`
  117. }
  118. type TradeClassifyName struct {
  119. ClassifyName string //分类名称
  120. ClassifyType string //分类名称下的类型
  121. LatestDate string //分类下最晚日期
  122. }
  123. // GetExchangeClassify 获取交易所分类列表
  124. func GetExchangeClassify(exchange string) (list []TradeClassifyName, err error) {
  125. tableName := "base_from_trade_" + exchange + "_index"
  126. orderStr := "classify_name DESC, classify_type asc"
  127. if exchange == "zhengzhou" {
  128. orderStr = "classify_name asc"
  129. }
  130. sql := "SELECT classify_name, classify_type FROM " + tableName + " WHERE `rank` <=20 and `rank` > 0 GROUP BY classify_name, classify_type "
  131. sql += ` ORDER BY ` + orderStr
  132. err = global.DbMap[utils.DbNameIndex].Raw(sql).Scan(&list).Error
  133. return
  134. }
  135. type LastTimeItem struct {
  136. CreateTime time.Time
  137. }
  138. // GetExchangeLastTime 获取交易所数据最晚的时间
  139. func GetExchangeLastTime(exchange string) (item LastTimeItem, err error) {
  140. tableName := "base_from_trade_" + exchange + "_index"
  141. sql := `SELECT create_time FROM ` + tableName + ` ORDER BY create_time desc`
  142. o := global.DbMap[utils.DbNameIndex]
  143. err = o.Raw(sql).Scan(&item).Error
  144. return
  145. }
  146. type GetPositionTopReq struct {
  147. Exchange string `json:"exchange" form:"exchange"` //交易所
  148. ClassifyName string `json:"classify_name" form:"classify_name"` //分类名称
  149. ClassifyType string `json:"classify_type" form:"classify_type"` //具体合约名称
  150. DataTime string `json:"data_time" form:"data_time"` //请求日期,如果为空,则返回最新的榜单日期
  151. }
  152. type GetPositionTopResp struct {
  153. BuyList GetPositionTopList `description:"多单列表"`
  154. SoldList GetPositionTopList `description:"空单列表"`
  155. CleanBuyList GetPositionTopList `description:"净多单列表"`
  156. CleanSoldList GetPositionTopList `description:"净空单列表"`
  157. DataTime string `description:"最新日期或者请求日期"`
  158. LastDataTime string `description:"最新日期"`
  159. }
  160. type GetPositionTopList struct {
  161. TotalDealValue int `description:"总计成交量"`
  162. TotalDealChange int `description:"校昨日变化"`
  163. List []GetPositionTopListItem `description:"榜单详情列表"`
  164. }
  165. type GetPositionTopListItem struct {
  166. DealShortName string `description:"成交量公司简称"`
  167. DealValue int `description:"成交量"`
  168. DealChange int `description:"成交变化量"`
  169. Rank int `description:"当前名次"`
  170. Rate string `description:"当前占比"`
  171. BeforeAllRate string `description:"排在前面的成交量总计占比(包含)"`
  172. BeforeAllValue int `description:"排在前面的成交量总计"`
  173. BeforeAllChange int `description:"排在前面的成交量增减总计"`
  174. }
  175. func GetTradePositionTop(exchange string, classifyName, classifyType, dataTime string) (list []TradePositionTop, err error) {
  176. tableName := "trade_position_" + exchange + "_top"
  177. sql := `SELECT * FROM ` + tableName + " WHERE classify_name=? and classify_type=? and data_time=? and `rank` <=20 and `rank` > 0 ORDER BY deal_value desc"
  178. err = global.DbMap[utils.DbNameIndex].Raw(sql, classifyName, classifyType, dataTime).Find(&list).Error
  179. return
  180. }
  181. type OriginTradeData struct {
  182. Rank int `description:"排名"`
  183. CompanyName string `description:"期货公司名称"`
  184. Val int `description:"持仓量"`
  185. ValChange int `description:"持仓增减"`
  186. DataTime time.Time `description:"数据日期"`
  187. ClassifyName string `description:"品种名称"`
  188. ClassifyType string `description:"合约代码"`
  189. ValType int `description:"数据类型: 1-多单; 2-空单"`
  190. }
  191. // BaseFromTradeCommonIndex 郑商所/大商所/上期所/上期能源指标表通用字段
  192. type BaseFromTradeCommonIndex struct {
  193. Rank int `description:"排名"`
  194. DealShortName string `description:"成交量公司简称"`
  195. DealName string `description:"成交量指标名称"`
  196. DealCode string `description:"成交量指标编码"`
  197. DealValue int `description:"成交量"`
  198. DealChange int `description:"成交变化量"`
  199. BuyShortName string `description:"持买单量公司简称"`
  200. BuyName string `description:"持买单量指标名称"`
  201. BuyCode string `description:"持买单量指标编码"`
  202. BuyValue int `description:"持买单量"`
  203. BuyChange int `description:"持买单量变化量"`
  204. SoldShortName string `description:"持卖单量公司简称"`
  205. SoldName string `description:"持卖单量指标名称"`
  206. SoldCode string `description:"持卖单量指标编码"`
  207. SoldValue int `description:"持卖单量"`
  208. SoldChange int `description:"持卖单变化量"`
  209. Frequency string `description:"频度"`
  210. ClassifyName string `description:"品种"`
  211. ClassifyType string `description:"合约"`
  212. CreateTime time.Time `description:"创建时间"`
  213. ModifyTime time.Time `description:"更新时间"`
  214. DataTime time.Time `description:"数据日期"`
  215. }
  216. // GetTradeDataByContracts 根据合约获取持仓数据
  217. func GetTradeDataByContracts(exchange string, classifyNames, contracts []string, startDate, endDate time.Time) (items []*BaseFromTradeCommonIndex, err error) {
  218. if exchange == "" {
  219. err = fmt.Errorf("数据表名称有误")
  220. return
  221. }
  222. var cond string
  223. var pars []interface{}
  224. if len(classifyNames) > 0 {
  225. cond += fmt.Sprintf(` AND classify_name IN (%s)`, utils.GetOrmInReplace(len(classifyNames)))
  226. pars = append(pars, classifyNames)
  227. }
  228. if len(contracts) > 0 {
  229. cond += fmt.Sprintf(` AND classify_type IN (%s)`, utils.GetOrmInReplace(len(contracts)))
  230. pars = append(pars, contracts)
  231. }
  232. if !startDate.IsZero() && !endDate.IsZero() {
  233. cond += ` AND (data_time BETWEEN ? AND ?)`
  234. pars = append(pars, startDate.Format(utils.FormatDate), endDate.Format(utils.FormatDate))
  235. }
  236. fields := []string{"rank", "buy_short_name", "buy_value", "buy_change", "sold_short_name", "sold_value", "sold_change", "classify_name", "classify_type", "data_time"}
  237. tableName := fmt.Sprintf("base_from_trade_%s_index", exchange)
  238. sql := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 %s ORDER BY data_time DESC`, strings.Join(fields, ","), tableName, cond)
  239. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Find(&items).Error
  240. return
  241. }
  242. // GetZhengzhouTradeDataByContracts 郑商所-根据合约获取持仓数据
  243. func GetZhengzhouTradeDataByContracts(classifyNames []string, startDate, endDate time.Time) (items []*BaseFromTradeCommonIndex, err error) {
  244. var cond string
  245. var pars []interface{}
  246. if len(classifyNames) > 0 {
  247. cond += fmt.Sprintf(` AND classify_name IN (%s)`, utils.GetOrmInReplace(len(classifyNames)))
  248. pars = append(pars, classifyNames)
  249. }
  250. if !startDate.IsZero() && !endDate.IsZero() {
  251. cond += ` AND (data_time BETWEEN ? AND ?)`
  252. pars = append(pars, startDate.Format(utils.FormatDate), endDate.Format(utils.FormatDate))
  253. }
  254. // ps.classify_name实为合约代码
  255. fields := []string{"rank", "buy_short_name", "buy_value", "buy_change", "sold_short_name", "sold_value", "sold_change", "classify_name AS classify_type", "data_time"}
  256. sql := fmt.Sprintf(`SELECT %s FROM base_from_trade_zhengzhou_index WHERE 1=1 %s ORDER BY data_time DESC`, strings.Join(fields, ","), cond)
  257. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Find(&items).Error
  258. return
  259. }
  260. // ContractCompanyTradeData [合约-期货公司]持仓数据
  261. type ContractCompanyTradeData struct {
  262. Exchange string `description:"交易所"`
  263. ClassifyName string `description:"品种"`
  264. ClassifyType string `description:"合约代码"`
  265. CompanyName string `description:"期货公司名称"`
  266. IsTotal bool `description:"是否为合约加总"`
  267. StartDate time.Time `description:"数据开始日期"`
  268. EndDate time.Time `description:"数据结束日期"`
  269. DataList []*ContractCompanyTradeDataList `description:"数据序列"`
  270. }
  271. // ContractCompanyTradeDataList [合约-期货公司]持仓数据详情
  272. type ContractCompanyTradeDataList struct {
  273. Date time.Time `description:"数据日期"`
  274. BuyVal int `description:"多单持仓量"`
  275. BuyValType int `description:"多单数据类型: 0-无值; 1-原始值; 2-推算值"`
  276. BuyChange int `description:"多单持仓增减"`
  277. BuyChangeType int `description:"多单持仓增减类型: 0-无值; 1-原始值; 2-推算值"`
  278. SoldVal int `description:"空单持仓量"`
  279. SoldValType int `description:"空单数据类型: 0-无值; 1-原始值; 2-推算值"`
  280. SoldChange int `description:"空单持仓增减"`
  281. SoldChangeType int `description:"空单持仓增减类型: 0-无值; 1-原始值; 2-推算值"`
  282. PureBuyVal int `description:"净多单持仓量"`
  283. PureBuyValType int `description:"净多单数据类型: 0-无值; 1-原始值; 2-推算值"`
  284. PureBuyChange int `description:"净多单持仓增减"`
  285. PureBuyChangeType int `description:"净多单持仓增减类型: 0-无值; 1-原始值; 2-推算值"`
  286. }
  287. type BaseFromTradeGuangzhouIndex struct {
  288. BaseFromTradeGuangzhouIndexId int `orm:"column(base_from_trade_guangzhou_index_id);pk"`
  289. BaseFromTradeGuangzhouClassifyId int `description:"分类id"`
  290. IndexCode string `description:"指标编码"`
  291. IndexName string `description:"指标名称"`
  292. Frequency string `description:"频率"`
  293. Unit string `description:"单位"`
  294. StartDate string `description:"开始日期"`
  295. EndDate string `description:"结束日期"`
  296. CreateTime time.Time `description:"创建日期"`
  297. ModifyTime time.Time `description:"修改日期"`
  298. }
  299. func GetBaseFromTradeGuangzhouIndex(classifyIds []int, contracts []string, indexKeyword string) (list []*BaseFromTradeGuangzhouIndex, err error) {
  300. cond := ``
  301. pars := make([]interface{}, 0)
  302. if len(classifyIds) > 0 {
  303. cond += fmt.Sprintf(` AND b.base_from_trade_guangzhou_classify_id IN (%s)`, utils.GetOrmInReplace(len(classifyIds)))
  304. pars = append(pars, classifyIds)
  305. }
  306. if len(contracts) > 0 {
  307. cond += fmt.Sprintf(` AND b.contract IN (%s)`, utils.GetOrmInReplace(len(contracts)))
  308. pars = append(pars, contracts)
  309. }
  310. if indexKeyword != "" {
  311. cond += fmt.Sprintf(` AND a.index_name LIKE ?`)
  312. pars = append(pars, indexKeyword)
  313. }
  314. sql := `SELECT a.* FROM base_from_trade_guangzhou_index AS a
  315. JOIN base_from_trade_guangzhou_contract AS b ON a.base_from_trade_guangzhou_contract_id = b.base_from_trade_guangzhou_contract_id
  316. WHERE 1=1 %s`
  317. sql = fmt.Sprintf(sql, cond)
  318. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Find(&list).Error
  319. return
  320. }
  321. type BaseFromTradeGuangzhouData struct {
  322. BaseFromTradeGuangzhouDataId int `orm:"column(base_from_trade_guangzhou_data_id);pk"`
  323. BaseFromTradeGuangzhouIndexId int `description:"指标id"`
  324. IndexCode string `description:"指标编码"`
  325. DataTime time.Time `description:"数据日期"`
  326. Value float64 `description:"数据值"`
  327. QtySub float64 `description:"增减"`
  328. CreateTime time.Time `description:"创建日期"`
  329. ModifyTime time.Time `description:"修改日期"`
  330. }
  331. // GetBaseFromTradeGuangzhouDataByIndexIds 广期所-获取指标数据
  332. func GetBaseFromTradeGuangzhouDataByIndexIds(indexIds []int, startDate, endDate time.Time) (list []*BaseFromTradeGuangzhouData, err error) {
  333. if len(indexIds) == 0 {
  334. return
  335. }
  336. cond := fmt.Sprintf(` AND base_from_trade_guangzhou_index_id IN (%s)`, utils.GetOrmInReplace(len(indexIds)))
  337. pars := make([]interface{}, 0)
  338. pars = append(pars, indexIds)
  339. if !startDate.IsZero() && !endDate.IsZero() {
  340. if startDate.Equal(endDate) {
  341. cond += ` AND data_time = ?`
  342. pars = append(pars, startDate.Format(utils.FormatDate))
  343. }
  344. if !startDate.Equal(endDate) {
  345. cond += ` AND (data_time BETWEEN ? AND ?)`
  346. pars = append(pars, startDate.Format(utils.FormatDate), endDate.Format(utils.FormatDate))
  347. }
  348. }
  349. sql := fmt.Sprintf(`SELECT * FROM base_from_trade_guangzhou_data WHERE 1=1 %s ORDER BY base_from_trade_guangzhou_index_id`, cond)
  350. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Find(&list).Error
  351. return
  352. }
  353. // ContractTopRankData TOP20合约排名数据
  354. type ContractTopRankData struct {
  355. Exchange string `description:"交易所"`
  356. DealValue int `description:"成交量"`
  357. BuyValue int `description:"多单持仓量"`
  358. BuyChange int `description:"多单变化"`
  359. SoldValue int `description:"空单持仓量"`
  360. SoldChange int `description:"空单变化"`
  361. PureBuyValue int `description:"净多单持仓量"`
  362. PureBuyChange int `description:"净多单变化"`
  363. ClassifyName string `description:"品种名称"`
  364. ClassifyType string `description:"合约代码"`
  365. DataTime time.Time `description:"数据日期"`
  366. }
  367. // GetContractTopRankData 获取合约TOP20根据当日成交量排名
  368. func GetContractTopRankData(exchange string, classifyNames []string, dataDate time.Time) (items []*ContractTopRankData, err error) {
  369. if exchange == "" {
  370. err = fmt.Errorf("数据表名称有误")
  371. return
  372. }
  373. if len(classifyNames) == 0 {
  374. return
  375. }
  376. tableName := fmt.Sprintf("base_from_trade_%s_index", exchange)
  377. // 大商所存在TOP20的rank=0
  378. queryRank := ` rank = 999`
  379. if exchange == TradeExchangeDalian {
  380. queryRank = ` (rank = 999 OR rank = 0)`
  381. }
  382. sql := `SELECT * FROM %s WHERE data_time = ? AND classify_name IN (%s) AND %s GROUP BY classify_type ORDER BY deal_value DESC`
  383. sql = fmt.Sprintf(sql, tableName, utils.GetOrmInReplace(len(classifyNames)), queryRank)
  384. err = global.DbMap[utils.DbNameIndex].Raw(sql, dataDate.Format(utils.FormatDate), classifyNames).Find(&items).Error
  385. return
  386. }
  387. // GetZhengzhouContractTopRankData 郑商所-获取合约根据当日成交量排名
  388. func GetZhengzhouContractTopRankData(classifyNames []string, dataDate time.Time) (items []*ContractTopRankData, err error) {
  389. if len(classifyNames) == 0 {
  390. return
  391. }
  392. sql := `SELECT * FROM base_from_trade_zhengzhou_index WHERE data_time = ? AND classify_name IN (%s) AND rank = 999 GROUP BY classify_name ORDER BY deal_value DESC`
  393. sql = fmt.Sprintf(sql, utils.GetOrmInReplace(len(classifyNames)))
  394. err = global.DbMap[utils.DbNameIndex].Raw(sql, dataDate.Format(utils.FormatDate), classifyNames).Find(&items).Error
  395. return
  396. }
  397. // ContractCompanyTradeEdb [合约-期货公司]指标
  398. type ContractCompanyTradeEdb struct {
  399. Exchange string `description:"交易所"`
  400. ClassifyName string `description:"品种"`
  401. ClassifyType string `description:"合约代码"`
  402. CompanyName string `description:"期货公司名称"`
  403. IsTotal bool `description:"是否为合约加总"`
  404. ContractPosition int `description:"合约方向"`
  405. StartDate time.Time `description:"数据开始日期"`
  406. EndDate time.Time `description:"数据结束日期"`
  407. DataList []*ContractCompanyTradeEdbData `description:"数据序列"`
  408. }
  409. // ContractCompanyTradeEdbData [合约-期货公司]指标数据
  410. type ContractCompanyTradeEdbData struct {
  411. DataTime time.Time `description:"数据日期"`
  412. Val int `description:"数据值"`
  413. }
  414. // GetClassifyNewestDataTime 获取品种最新数据日期
  415. func GetClassifyNewestDataTime(exchange string, classifyNames []string) (dateTime time.Time, err error) {
  416. if exchange == "" {
  417. err = fmt.Errorf("数据表名称有误")
  418. return
  419. }
  420. if len(classifyNames) == 0 {
  421. return
  422. }
  423. tableName := fmt.Sprintf("base_from_trade_%s_index", exchange)
  424. sql := `SELECT data_time FROM %s WHERE classify_name IN (%s) ORDER BY data_time DESC LIMIT 1`
  425. sql = fmt.Sprintf(sql, tableName, utils.GetOrmInReplace(len(classifyNames)))
  426. err = global.DbMap[utils.DbNameIndex].Raw(sql, classifyNames).First(&dateTime).Error
  427. return
  428. }
  429. // GetGuangzhouClassifyNewestDataTime 广期所-获取品种最新数据日期
  430. func GetGuangzhouClassifyNewestDataTime(indexIds []int) (dateTime time.Time, err error) {
  431. if len(indexIds) == 0 {
  432. return
  433. }
  434. cond := fmt.Sprintf(` AND base_from_trade_guangzhou_index_id IN (%s)`, utils.GetOrmInReplace(len(indexIds)))
  435. pars := make([]interface{}, 0)
  436. pars = append(pars, indexIds)
  437. sql := fmt.Sprintf(`SELECT data_time FROM base_from_trade_guangzhou_data WHERE 1=1 %s ORDER BY data_time DESC LIMIT 1`, cond)
  438. err = global.DbMap[utils.DbNameIndex].Raw(sql, pars...).Find(&dateTime).Error
  439. return
  440. }