123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 |
- package trade_analysis
- import (
- "hongze/hongze_yb/global"
- "time"
- )
- type TradePositionTop struct {
- Id uint64 `gorm:"primaryKey;column:id" json:"id"`
- ClassifyName string `gorm:"column:classify_name" json:"classify_name"`
- ClassifyType string `gorm:"column:classify_type" json:"classify_type"`
- DealShortName string `gorm:"column:deal_short_name" json:"deal_short_name"`
- DealValue int `gorm:"column:deal_value" json:"deal_value"`
- DealChange int `gorm:"column:deal_change" json:"deal_change"`
- DataTime time.Time `gorm:"column:data_time" json:"data_time"`
- CreateTime time.Time `gorm:"column:create_time" json:"create_time"`
- ModifyTime time.Time `gorm:"column:modify_time" json:"modify_time"`
- DealType int `gorm:"column:deal_type" json:"deal_type"`
- SourceType int `gorm:"column:source_type" json:"source_type"`
- Rank int `gorm:"column:rank" json:"rank"`
- }
- type TradeClassifyNameList struct {
- Exchange string `description:"交易所" json:"exchange"`
- Sort int `description:"排序字段" json:"sort"`
- Num int `description:"品种数量" json:"num"`
- DataTime string `description:"最新更新时间" json:"data_time"`
- CurrDate string `description:"当前日期" json:"curr_date"`
- Items []TradeClassifyNameListItem `description:"子类" json:"items"`
- }
- type TradeClassifyNameListSort []TradeClassifyNameList
- func (v TradeClassifyNameListSort) Len() int {
- return len(v)
- }
- func (v TradeClassifyNameListSort) Swap(i, j int) {
- v[i], v[j] = v[j], v[i]
- }
- func (v TradeClassifyNameListSort) Less(i, j int) bool {
- return v[i].Sort < v[j].Sort
- }
- type TradeClassifyNameListItemSort []TradeClassifyNameListItem
- func (v TradeClassifyNameListItemSort) Len() int {
- return len(v)
- }
- func (v TradeClassifyNameListItemSort) Swap(i, j int) {
- v[i], v[j] = v[j], v[i]
- }
- func (v TradeClassifyNameListItemSort) Less(i, j int) bool {
- return v[i].ClassifyName < v[j].ClassifyName
- }
- type TradeClassifyNameListItem struct {
- ClassifyName string `description:"交易分类" json:"classify_name"`
- Items []TradeClassifyNameListItemItem `description:"合约代码" json:"items"`
- }
- type TradeClassifyNameListItemItemSort []TradeClassifyNameListItemItem
- func (v TradeClassifyNameListItemItemSort) Len() int {
- return len(v)
- }
- func (v TradeClassifyNameListItemItemSort) Swap(i, j int) {
- v[i], v[j] = v[j], v[i]
- }
- func (v TradeClassifyNameListItemItemSort) Less(i, j int) bool {
- return v[i].ClassifyType < v[j].ClassifyType
- }
- type TradeClassifyNameListItemItem struct {
- ClassifyType string `json:"classify_type"`
- }
- type TradeClassifyName struct {
- ClassifyName string
- ClassifyType string
- LatestDate string
- }
- func GetExchangeClassify(exchange string) (list []TradeClassifyName, err error) {
- tableName := "base_from_trade_" + exchange + "_index"
- orderStr := "classify_name DESC, classify_type asc"
- if exchange == "zhengzhou" {
- orderStr = "classify_name asc"
- }
- err = global.MYSQL["data"].
- Table(tableName).
- Select("classify_name, classify_type").
- Group("classify_name, classify_type").
- Where("rank <=20 and rank > 0 ").
- Order(orderStr).Scan(&list).Error
- return
- }
- type LastTimeItem struct {
- CreateTime time.Time
- }
- func GetExchangeLastTime(exchange string) (item LastTimeItem, err error) {
- tableName := "base_from_trade_" + exchange + "_index"
- err = global.MYSQL["data"].
- Table(tableName).
- Select("create_time").
- Order("create_time desc").First(&item).Error
- return
- }
- type GetPositionTopReq struct {
- Exchange string `json:"exchange" form:"exchange"`
- ClassifyName string `json:"classify_name" form:"classify_name"`
- ClassifyType string `json:"classify_type" form:"classify_type"`
- DataTime string `json:"data_time" form:"data_time"`
- }
- type GetPositionTopResp struct {
- BuyList GetPositionTopList `json:"buy_list"`
- SoldList GetPositionTopList `json:"sold_list"`
- CleanBuyList GetPositionTopList `json:"clean_buy_list"`
- CleanSoldList GetPositionTopList `json:"clean_sold_list"`
- DataTime string `json:"data_time"`
- LastDataTime string `json:"last_data_time" description:"最新日期"`
- }
- type GetPositionTopList struct {
- TotalDealValue int `json:"total_deal_value"`
- TotalDealChange int `json:"total_deal_change"`
- List []GetPositionTopListItem `json:"list"`
- }
- type GetPositionTopListItem struct {
- DealShortName string `json:"deal_short_name"`
- DealValue int `json:"deal_value"`
- DealChange int `json:"deal_change"`
- Rank int `json:"rank"`
- Rate string `json:"rate"`
- BeforeAllRate string `json:"before_all_rate"`
- BeforeAllValue int `json:"before_all_value"`
- BeforeAllChange int `json:"before_all_change"`
- }
- func GetTradePositionTop(exchange string, classifyName, classifyType, dataTime string) (list []TradePositionTop, err error) {
- tableName := "trade_position_" + exchange + "_top"
- err = global.MYSQL["data"].
- Table(tableName).
- Where("classify_name=? and classify_type=? and data_time=? and rank <=20 and rank > 0", classifyName, classifyType, dataTime).
- Order("deal_value desc").Scan(&list).Error
- return
- }
- type BaseFromTradeClassify struct {
- Id uint64 `orm:"column(id);pk"`
- ClassifyName string
- ClassifyType string
- Exchange string
- LatestDate time.Time
- CreateTime time.Time
- ModifyTime time.Time
- }
- func GetAllBaseFromTradeClassify() (list []*BaseFromTradeClassify, err error) {
- err = global.MYSQL["data"].Table("base_from_trade_classify").Find(&list).Error
- return
- }
- func GetTradeTopLastDataTime(exchange string, classifyName, classifyType string) (item *BaseFromTradeClassify, err error) {
- tableName := "base_from_trade_classify"
- if exchange == "zhengzhou" {
- err = global.MYSQL["data"].
- Table(tableName).
- Where("exchange = ? AND classify_name=? ", exchange, classifyType).
- Order("latest_date desc").First(&item).Error
- } else {
- err = global.MYSQL["data"].
- Table(tableName).
- Where("exchange = ? AND classify_name=? and classify_type=?", exchange, classifyName, classifyType).
- Order("latest_date desc").First(&item).Error
- }
- return
- }
- func GetZhengzhouClassifyTypeByClassifyName(classifyName string) (item *TradeClassifyName, err error) {
- tableName := "base_from_trade_zhengzhou_index"
- err = global.MYSQL["data"].
- Table(tableName).
- Select("classify_name, classify_type").
- Where("classify_name=?", classifyName).Limit(1).Find(&item).Error
- return
- }
|