hsby.go 69 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283
  1. package models
  2. import (
  3. "encoding/hex"
  4. "fmt"
  5. "math"
  6. "mtp2_if/db"
  7. "mtp2_if/utils"
  8. "strconv"
  9. "time"
  10. )
  11. // Hsbygoodsex 商品扩展表
  12. type Hsbygoodsex struct {
  13. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商 品ID
  14. Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
  15. Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)
  16. Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)
  17. Vendorid int32 `json:"vendorid" xorm:"'VENDORID'"` // 供应商ID
  18. Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
  19. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  20. Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
  21. Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
  22. Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  23. Memberratio float64 `json:"memberratio" xorm:"'MEMBERRATIO'"` // 会员货款比例 [71]
  24. Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
  25. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  26. }
  27. // TableName is HSBY_GOODSEX
  28. func (Hsbygoodsex) TableName() string {
  29. return "HSBY_GOODSEX"
  30. }
  31. // Hsbysupplierinfo 供应商表
  32. type Hsbysupplierinfo struct {
  33. Vendorid int32 `json:"vendorid" xorm:"'VENDORID'" binding:"required"` // 供应商ID(SEQ_HSBY_SUPPLIERINFO)
  34. Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 名称描述客服电话名称
  35. Vendordesc string `json:"vendordesc" xorm:"'VENDORDESC'"` // 描述
  36. Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 客服电话
  37. Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 附件(多张,逗号分隔)
  38. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  39. Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
  40. Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
  41. Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  42. }
  43. // TableName is HSBY_SUPPLIERINFO
  44. func (Hsbysupplierinfo) TableName() string {
  45. return "HSBY_SUPPLIERINFO"
  46. }
  47. // Tradepayorder 交易待付款表
  48. type Tradepayorder struct {
  49. Tradeid int64 `json:"tradeid" xorm:"'TRADEID'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  50. Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
  51. Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
  52. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
  53. Buyorderid int64 `json:"buyorderid" xorm:"'BUYORDERID'"` // 买方委托单号
  54. Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
  55. Sellorderid int64 `json:"sellorderid" xorm:"'SELLORDERID'"` // 卖方委托单号
  56. Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
  57. Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
  58. Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
  59. Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
  60. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  61. Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
  62. Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
  63. Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
  64. Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
  65. Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
  66. Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
  67. }
  68. // TableName is TRADE_PAYORDER
  69. func (Tradepayorder) TableName() string {
  70. return "TRADE_PAYORDER"
  71. }
  72. // HsbyTopGoods 热卖商品(二级市场挂牌点选)
  73. type HsbyTopGoods struct {
  74. Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
  75. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  76. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  77. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  78. Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
  79. Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
  80. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  81. Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
  82. Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
  83. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  84. Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
  85. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  86. Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  87. Last float64 `json:"last" xorm:"-"` // 现价
  88. }
  89. // GetHsbyTopGoodses 获取热门商品列表
  90. // 参数 marketIDs string 所属市场ID列表, 格式 1,2,3
  91. // 参数 descProvinceID int 目标省ID
  92. // 参数 descCityID int 目标城市ID
  93. // 返回 []TopGoods 热门商品列表
  94. // 返回 error error
  95. func GetHsbyTopGoodses(marketIDs string, descProvinceID, descCityID int) ([]HsbyTopGoods, error) {
  96. // 热门商品为二级市场(挂牌点选)下的商品信息
  97. engine := db.GetEngine()
  98. topGoodses := make([]HsbyTopGoods, 0)
  99. // 获取挂牌商品信息,以及扩展表信息
  100. session := engine.Table("GOODS").
  101. Select(`GOODS.*,
  102. HSBY_GOODSEX.HOTINDEX, HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS,
  103. ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
  104. MARKET.TRADEMODE`).
  105. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  106. Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
  107. Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
  108. Where(fmt.Sprintf("GOODS.GOODSSTATUS = 3 and GOODS.MARKETID in (%s)", marketIDs)) // 二级市场只获取 3:上市 状态的商品
  109. if descProvinceID > 0 {
  110. session = session.And("HSBY_GOODSEX.DESCPROVINCEID = ?", descProvinceID)
  111. }
  112. if descCityID > 0 {
  113. session = session.And("HSBY_GOODSEX.DESCCITYID = ?", descCityID)
  114. }
  115. if err := session.Find(&topGoodses); err != nil {
  116. return nil, err
  117. }
  118. if len(topGoodses) == 0 {
  119. // 无数据
  120. return topGoodses, nil
  121. }
  122. // 获取商品ID列表
  123. goodsCodes := ""
  124. for _, v := range topGoodses {
  125. if len(goodsCodes) == 0 {
  126. goodsCodes = v.Goodscode
  127. } else {
  128. goodsCodes += "," + v.Goodscode
  129. }
  130. }
  131. // 获取商品现价
  132. quoteDays, err := GetQuoteDays(goodsCodes)
  133. if err != nil {
  134. return nil, err
  135. }
  136. for i, g := range topGoodses {
  137. topGoods := &topGoodses[i]
  138. // FIXME: - 这里应该使用 Duck Typing,后期再处理
  139. // 计算最小变动单位
  140. // lotSize := float64(topGoods.Quoteminunit) * math.Pow(0.1, float64(topGoods.Decimalplace))
  141. // topGoods.LotSize, _ = strconv.ParseFloat(utils.FormatFloat(lotSize, int(topGoods.Decimalplace)), 64)
  142. for _, q := range quoteDays {
  143. if g.Goodscode == q.Goodscode {
  144. if q.Last != 0 {
  145. topGoods.Last = utils.IntToFloat64(int(q.Last), int(g.Decimalplace))
  146. }
  147. // 没有现价则尝试用昨结
  148. if topGoods.Last == 0 && q.Presettle != 0 {
  149. topGoods.Last = utils.IntToFloat64(int(q.Presettle), int(g.Decimalplace))
  150. }
  151. continue
  152. }
  153. }
  154. }
  155. return topGoodses, nil
  156. }
  157. // HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情
  158. type HsbyListingGoodsDetail struct {
  159. Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
  160. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  161. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  162. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  163. Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
  164. Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
  165. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  166. Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
  167. Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
  168. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  169. Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)ID
  170. Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)ID
  171. Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
  172. Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
  173. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  174. Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
  175. Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 供应商客服电话
  176. Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 供应商附件(多张,逗号分隔)
  177. Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  178. Last float64 `json:"last" xorm:"-"` // 现价
  179. Limitup float64 `json:"limitup" xorm:"-"` // 涨停价
  180. Limitdown float64 `json:"limitdown" xorm:"-"` // 跌停价
  181. StepValue float64 `json:"stepvalue" xorm:"-"` // 价格最小变动单位
  182. LotSize int `json:"lotsize" xorm:"-"` // 手数最小变动单位
  183. }
  184. // GetHsbyListingGoodsDetail 获取二级市场(挂牌点选)商品信息详情
  185. // 参数 goodsID int 目标商品ID
  186. // 返回 *HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情,查询无结果返回nil
  187. // 返回 error error
  188. func GetHsbyListingGoodsDetail(goodsID int) (*HsbyListingGoodsDetail, error) {
  189. engine := db.GetEngine()
  190. details := make([]HsbyListingGoodsDetail, 0)
  191. // 获取挂牌商品信息,以及扩展表信息
  192. // FIXME: - 这里使用Get方法,会造成SQL语句的嵌套出错,后期再研究
  193. session := engine.Table("GOODS").
  194. Select(`GOODS.GOODSID, GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.MARKETID, GOODS.QUOTEMINUNIT, GOODS.AGREEUNIT,
  195. HSBY_GOODSEX.HOTINDEX, HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS, HSBY_GOODSEX.DESCPROVINCEID, HSBY_GOODSEX.Desccityid, HSBY_GOODSEX.Goodsdesc,
  196. ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
  197. HSBY_SUPPLIERINFO.VENDORNAME, HSBY_SUPPLIERINFO.VENDORPHONE, HSBY_SUPPLIERINFO.VENDORATTR,
  198. MARKET.TRADEMODE`).
  199. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  200. Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
  201. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  202. Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
  203. Where("GOODS.GOODSID = ?", goodsID)
  204. if err := session.Find(&details); err != nil {
  205. return nil, err
  206. }
  207. // 无目标商品
  208. if len(details) == 0 {
  209. return nil, nil
  210. }
  211. hsbyListingGoodsDetail := details[0]
  212. // 获取商品现价和涨跌停价
  213. quoteDays, err := GetQuoteDays(hsbyListingGoodsDetail.Goodscode)
  214. if err != nil {
  215. return nil, err
  216. }
  217. if len(quoteDays) > 0 {
  218. if quoteDays[0].Last != 0 {
  219. hsbyListingGoodsDetail.Last = utils.IntToFloat64(int(quoteDays[0].Last), int(hsbyListingGoodsDetail.Decimalplace))
  220. }
  221. // 没有现价则尝试用昨结
  222. if hsbyListingGoodsDetail.Last == 0 && quoteDays[0].Presettle != 0 {
  223. hsbyListingGoodsDetail.Last = utils.IntToFloat64(int(quoteDays[0].Presettle), int(hsbyListingGoodsDetail.Decimalplace))
  224. }
  225. if quoteDays[0].Limitup != 0 {
  226. hsbyListingGoodsDetail.Limitup = utils.IntToFloat64(int(quoteDays[0].Limitup), int(hsbyListingGoodsDetail.Decimalplace))
  227. }
  228. if quoteDays[0].Limitdown != 0 {
  229. hsbyListingGoodsDetail.Limitdown = utils.IntToFloat64(int(quoteDays[0].Limitdown), int(hsbyListingGoodsDetail.Decimalplace))
  230. }
  231. }
  232. // 计算价格最小变动单位
  233. stepValue := float64(hsbyListingGoodsDetail.Quoteminunit) * math.Pow(0.1, float64(hsbyListingGoodsDetail.Decimalplace))
  234. hsbyListingGoodsDetail.StepValue, _ = strconv.ParseFloat(utils.FormatFloat(stepValue, int(hsbyListingGoodsDetail.Decimalplace)), 64)
  235. // 计算手数最小变动单位
  236. hsbyListingGoodsDetail.LotSize = 1
  237. return &hsbyListingGoodsDetail, nil
  238. }
  239. // HsbyGoodsOrderDetail 二级市场挂牌商品当前可摘委托单信息
  240. type HsbyGoodsOrderDetail struct {
  241. Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  242. Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
  243. Ordertime time.Time `json:"ordertime" xorm:"'ORDERTIME'" binding:"required"` // 委托时间
  244. Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
  245. Enableqty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 可用数量
  246. Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 客户名称(企业名称),已脱敏
  247. Currencysign string `json:"currencysign" xorm:"-"` // 货币符号
  248. Goodunit string `json:"goodunit" xorm:"-"` // 报价单位
  249. }
  250. // GetHsbyGoodsOrderDetails 获取二级市场(挂牌点选)商品对应的挂牌委托单信息
  251. // 输入 goodsID int 商品ID
  252. // 输入 buyOrSell int 挂牌委托单方向(对手单方向),0:买 1:卖
  253. // 输入 price float64 参考价格。买方向委托单则价格小于等于(站在摘牌人的角度);卖方向委托单则价格大于等于
  254. // 输出 []HsbyGoodsOrderDetail 商品对应的挂牌委托单信息
  255. // 输出 error error
  256. func GetHsbyGoodsOrderDetails(goodsID, buyOrSell int, price float64, accountIDs string) ([]HsbyGoodsOrderDetail, error) {
  257. engine := db.GetEngine()
  258. // 获取与目标商品相关的挂牌委托单信息(ListingSelectType = 1 or 3; OrderStatus =3 or 7)
  259. hsbyGoodsOrderDetails := make([]HsbyGoodsOrderDetail, 0)
  260. session := engine.Table("TRADE_ORDERDETAIL").
  261. Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID, TRADE_ORDERDETAIL.BUYORSELL, TRADE_ORDERDETAIL.ORDERTIME, TRADE_ORDERDETAIL.ORDERPRICE, (TRADE_ORDERDETAIL.ORDERQTY - TRADE_ORDERDETAIL.TRADEQTY - TRADE_ORDERDETAIL.CANCELQTY) ENABLEQTY,
  262. substr(USERINFO.CUSTOMERNAME,0,1)||'****' as CUSTOMERNAME`).
  263. Join("LEFT", "TAACCOUNT", "TAACCOUNT.ACCOUNTID = TRADE_ORDERDETAIL.ACCOUNTID").
  264. Join("LEFT", "USERINFO", "USERINFO.USERID = TAACCOUNT.RELATEDUSERID").
  265. Where("(TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 1 or TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 3) and (TRADE_ORDERDETAIL.ORDERSTATUS = 3 or TRADE_ORDERDETAIL.ORDERSTATUS = 7)").
  266. And("TRADE_ORDERDETAIL.GOODSID = ?", goodsID).
  267. And("TRADE_ORDERDETAIL.BUYORSELL = ?", buyOrSell)
  268. if len(accountIDs) > 0 {
  269. session = session.And(fmt.Sprintf("TRADE_ORDERDETAIL.ACCOUNTID not in (%s)", accountIDs))
  270. }
  271. if price > 0 {
  272. if buyOrSell == 0 {
  273. // 对手单买方向委托单则价格大于等于(站在摘牌人的角度,摘牌方面是卖,我的闲置下单)
  274. session = session.And("TRADE_ORDERDETAIL.ORDERPRICE >= ?", price)
  275. } else {
  276. // 对手单卖方向委托单则价格小于等于(站在摘牌人的角度,摘牌方面是买,热门商品下单)
  277. session = session.And("TRADE_ORDERDETAIL.ORDERPRICE <= ?", price)
  278. }
  279. }
  280. if err := session.Find(&hsbyGoodsOrderDetails); err != nil {
  281. return nil, err
  282. }
  283. // 获取商品货币符号和报价单位
  284. goods, err := GetGoods(goodsID)
  285. if err != nil {
  286. return nil, err
  287. }
  288. currencyEnums, err := GetEnumDicItem("currency", int(goods.Currencyid))
  289. if err != nil {
  290. return nil, err
  291. }
  292. currencysign := ""
  293. if len(currencyEnums) > 0 {
  294. currencysign = currencyEnums[0].Param2
  295. }
  296. goodsUnitEnums, err := GetEnumDicItem("goodsunit", int(goods.Goodunitid))
  297. if err != nil {
  298. return nil, err
  299. }
  300. goodsUnit := ""
  301. if len(goodsUnitEnums) > 0 {
  302. goodsUnit = goodsUnitEnums[0].Enumdicname
  303. }
  304. for i := range hsbyGoodsOrderDetails {
  305. orderDetail := &hsbyGoodsOrderDetails[i]
  306. // 设置货币符号和报价单位
  307. orderDetail.Currencysign = currencysign
  308. orderDetail.Goodunit = goodsUnit
  309. }
  310. return hsbyGoodsOrderDetails, nil
  311. }
  312. // HybsMyBuyOrderDetail 我的订单(一二级市场的买方向委托单)
  313. type HybsMyBuyOrderDetail struct {
  314. Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  315. Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
  316. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
  317. Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
  318. Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
  319. Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
  320. Orderqty int64 `json:"orderqty" xorm:"'ORDERQTY'" binding:"required"` // 委托数量
  321. Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
  322. Cancelqty int64 `json:"cancelqty" xorm:"'CANCELQTY'"` // 撤单数量
  323. Ordertime time.Time `json:"ordertime" xorm:"'ORDERTIME'" binding:"required"` // 委托时间
  324. Listingselecttype int32 `json:"listingselecttype" xorm:"'LISTINGSELECTTYPE'"` // 挂牌点选类型 - 1:挂牌 2:摘牌 3:先摘后挂
  325. Orderstatus int32 `json:"orderstatus" xorm:"'ORDERSTATUS'"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
  326. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  327. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  328. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  329. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  330. Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
  331. Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
  332. Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  333. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  334. Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
  335. Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
  336. MyBuyStatus int `json:"mybuystatus" xorm:"-"` // "我的订单"显示状态- 1:抢购中 2:求购中 3:已完成 4:已撤消 5:委托失败
  337. Orderamount float64 `json:"orderamount" xorm:"-"` // 委托金额
  338. }
  339. // GetHsbyBuyMyOrderDetails 获取“我的订单”数据(包括一二级市场)
  340. // 输入 accountIDs string 资金账户列表
  341. // 输入 myBuyStatus int "我的订单"状态, 1:抢购中 2:求购中 3:已完成
  342. // 输出 []HybsMyBuyOrderDetail “我的订单”数据
  343. // 输出 error error
  344. func GetHsbyBuyMyOrderDetails(accountIDs string, myBuyStatus int) ([]HybsMyBuyOrderDetail, error) {
  345. // 获取市场信息
  346. markets, err := GetMarkets()
  347. if err != nil {
  348. return nil, err
  349. }
  350. engine := db.GetEngine()
  351. // 委托状态
  352. orderStatus := "0" // 单据状态,为0的时候查询全部
  353. marketIDs := "" // 我的订单包括一二级市场的单据
  354. switch myBuyStatus {
  355. case 1: // 抢购中 (一级市场)
  356. // 获取市场ID
  357. for _, v := range markets {
  358. if v.Trademode == 71 { // 预售挂牌
  359. if len(marketIDs) == 0 {
  360. marketIDs = strconv.Itoa(int(v.Marketid))
  361. } else {
  362. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  363. }
  364. }
  365. }
  366. orderStatus = "3,7"
  367. case 2: // 求购中(二级市场)
  368. // 获取市场ID
  369. for _, v := range markets {
  370. if v.Trademode == 16 { // 挂牌点选
  371. if len(marketIDs) == 0 {
  372. marketIDs = strconv.Itoa(int(v.Marketid))
  373. } else {
  374. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  375. }
  376. }
  377. }
  378. orderStatus = "3,7"
  379. case 3: // 已完成
  380. orderStatus = "8,9"
  381. }
  382. // 默认取 TradeMode = 16 or 71 的市场
  383. if len(marketIDs) == 0 {
  384. for _, v := range markets {
  385. if v.Trademode == 16 || v.Trademode == 71 {
  386. if len(marketIDs) == 0 {
  387. marketIDs = strconv.Itoa(int(v.Marketid))
  388. } else {
  389. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  390. }
  391. }
  392. }
  393. }
  394. hybsMyBuyOrderDetails := make([]HybsMyBuyOrderDetail, 0)
  395. // "我的订单"都是买委托
  396. session := engine.Table("TRADE_ORDERDETAIL").
  397. Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID, TRADE_ORDERDETAIL.*,
  398. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  399. HG1.PICURLS PICURLS1,
  400. HG2.PICURLS PICURLS2,
  401. MARKET.TRADEMODE,
  402. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  403. HS1.VENDORNAME VENDORNAME1,
  404. HS2.VENDORNAME VENDORNAME2`).
  405. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_ORDERDETAIL.GOODSID").
  406. Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = TRADE_ORDERDETAIL.GOODSID").
  407. Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
  408. Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
  409. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  410. Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_ORDERDETAIL.MARKETID").
  411. Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
  412. Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
  413. Where(fmt.Sprintf("TRADE_ORDERDETAIL.BUYORSELL = 0 and TRADE_ORDERDETAIL.ACCOUNTID in (%s)", accountIDs)).
  414. And(fmt.Sprintf("TRADE_ORDERDETAIL.MARKETID in (%s)", marketIDs))
  415. // 是否过滤状态(抢购中、求购中、已完成)
  416. if orderStatus != "0" {
  417. session = session.And(fmt.Sprintf("TRADE_ORDERDETAIL.ORDERSTATUS in (%s)", orderStatus))
  418. }
  419. if err := session.Find(&hybsMyBuyOrderDetails); err != nil {
  420. return nil, err
  421. }
  422. // 设置“我的订单”显示状态
  423. for i := range hybsMyBuyOrderDetails {
  424. detail := &hybsMyBuyOrderDetails[i]
  425. // 委托金额 = 委托价格 * 委托数量 * 合约单位
  426. detail.Orderamount = detail.Orderprice * float64(detail.Orderqty) * float64(detail.Agreeunit)
  427. if detail.Trademode == 71 && (detail.Orderstatus == 3 || detail.Orderstatus == 7) {
  428. // 抢购中
  429. detail.MyBuyStatus = 1
  430. } else if detail.Trademode == 16 && (detail.Orderstatus == 3 || detail.Orderstatus == 7) {
  431. // 求购中
  432. detail.MyBuyStatus = 2
  433. } else if detail.Orderstatus == 8 || detail.Orderstatus == 9 {
  434. // 已完成
  435. detail.MyBuyStatus = 3
  436. } else if detail.Orderstatus == 6 {
  437. // 已撤销
  438. detail.MyBuyStatus = 4
  439. } else if detail.Orderstatus == 4 {
  440. // 委托失败
  441. detail.MyBuyStatus = 5
  442. }
  443. }
  444. return hybsMyBuyOrderDetails, nil
  445. }
  446. // HsbyMyGoods 我的商品(买方向持仓)
  447. type HsbyMyGoods struct {
  448. Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账号Id
  449. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品Id
  450. Buycurpositionqty int64 `json:"buycurpositionqty" xorm:"'BUYCURPOSITIONQTY'"` // 买当前持仓总数量
  451. Buycurholderamount float64 `json:"buycurholderamount" xorm:"'BUYCURHOLDERAMOUNT'"` // 买当前持仓总金额[商品币种]
  452. EnableQty int64 `json:"enableqty" xorm:"'ENABLEQTY'"` // 可用数量
  453. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  454. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  455. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  456. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  457. Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 1:待审核 2:未上市 3:上市 4:已注销 5:审核拒绝 6:退市 7:待退市
  458. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  459. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  460. Buyaverageprice float64 `json:"buyaverageprice" xorm:"-"` // 持仓均价
  461. }
  462. // GetHsbyMyGoods 获取“我的商品”信息
  463. // 输入 accountIDs string 资金账户列表,格式 1,2,3
  464. // 输出 []HsbyMyGoods “我的商品”信息
  465. // 输入 error error
  466. func GetHsbyMyGoods(accountIDs string) ([]HsbyMyGoods, error) {
  467. engine := db.GetEngine()
  468. hsbyMyGoodses := make([]HsbyMyGoods, 0)
  469. // 此定制版本,只查询出当前手数(期末)大于0的数据 (TRADEPOSITION.BUYCURPOSITIONQTY > 0)
  470. if err := engine.Table("TRADEPOSITION").
  471. Select(`TRADEPOSITION.*, (TRADEPOSITION.BUYCURPOSITIONQTY - TRADEPOSITION.BUYFROZENQTY - TRADEPOSITION.BUYOTHERFROZENQTY) ENABLEQTY,
  472. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT, GOODS.GOODSSTATUS,
  473. HSBY_GOODSEX.PICURLS,
  474. ENUMDICITEM.PARAM2 CURRENCYSIGN`).
  475. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADEPOSITION.GOODSID").
  476. Join("INNER", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  477. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  478. Where(fmt.Sprintf("TRADEPOSITION.BUYCURPOSITIONQTY > 0 and TRADEPOSITION.ACCOUNTID in (%s)", accountIDs)).Find(&hsbyMyGoodses); err != nil {
  479. return nil, err
  480. }
  481. for i := range hsbyMyGoodses {
  482. myGoods := &hsbyMyGoodses[i]
  483. // 持仓均价
  484. averagePrice := myGoods.Buycurholderamount / float64(myGoods.Buycurpositionqty) / myGoods.Agreeunit
  485. myGoods.Buyaverageprice, _ = strconv.ParseFloat(utils.FormatFloat(averagePrice, int(myGoods.Decimalplace)), 64)
  486. }
  487. return hsbyMyGoodses, nil
  488. }
  489. // HsbyPreGoods 新品上市商品(一级市场产能预售)
  490. type HsbyPreGoods struct {
  491. Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
  492. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  493. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  494. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  495. Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
  496. Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 2:未上市 3:上市
  497. Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
  498. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  499. Listingdate time.Time `json:"listingdate" xorm:"'LISTINGDATE'"` // 交易开始日期
  500. Lasttradedate time.Time `json:"lasttradedate" xorm:"'LASTTRADEDATE'"` // 最后交易日期(状态:待退市)
  501. Relatedgoodsid int64 `json:"relatedgoodsid" xorm:"'RELATEDGOODSID'"` // 关联交易合约ID
  502. Presaleqty int64 `json:"presaleqty" xorm:"'PRESALEQTY'"` // 预售数量
  503. Refprice float64 `json:"refprice" xorm:"'REFPRICE'"` // 参考价格[一口价]
  504. Presaledqty int64 `json:"presaledqty" xorm:"'PRESALEDQTY'"` // 已预售量(预售结束时更新)
  505. EnableQty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 剩余数量
  506. Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
  507. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  508. Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
  509. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  510. Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  511. }
  512. // GetHsbyPreGoodses 获取“新品上市”商品列表(一级市场产能预售)
  513. // 输入 marketIDs string 市场ID列表,格式 1,2,3
  514. // 输入 descProvinceID int 省ID
  515. // 输入 descCityID int 市ID
  516. // 输出 []HsbyPreGoods “新品上市”商品列表
  517. // 输出 error error
  518. func GetHsbyPreGoodses(marketIDs string, descProvinceID, descCityID int) ([]HsbyPreGoods, error) {
  519. engine := db.GetEngine()
  520. // 注意:一级产能预售市场使用的商品实际上是和二级市场有关系的,所以要使用 CPTRADE_PRESALEGOODSEX.RELATEDGOODSID 进行关联
  521. // 注意:CPTRADE_PRESALEGOODSEX 表的开始与结束时间是给大宗用的
  522. preGoodses := make([]HsbyPreGoods, 0)
  523. session := engine.Table("GOODS").
  524. Select(`GOODS.*,
  525. CPTRADE_PRESALEGOODSEX.RELATEDGOODSID, CPTRADE_PRESALEGOODSEX.PRESALEQTY, CPTRADE_PRESALEGOODSEX.REFPRICE,
  526. CPTRADE_PRESALEGOODSEX.PRESALEDQTY, (CPTRADE_PRESALEGOODSEX.PRESALEQTY - CPTRADE_PRESALEGOODSEX.PRESALEDQTY) ENABLEQTY,
  527. ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
  528. HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS,
  529. MARKET.TRADEMODE`).
  530. Join("INNER", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = GOODS.GOODSID").
  531. Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
  532. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
  533. Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
  534. Where(fmt.Sprintf("GOODS.GOODSSTATUS in (2,3) and GOODS.MARKETID in (%s)", marketIDs)) // 一级市场获取 2:未上市 3:上市 状态的商品
  535. if descProvinceID > 0 {
  536. session = session.And("HSBY_GOODSEX.DESCPROVINCEID = ?", descProvinceID)
  537. }
  538. if descCityID > 0 {
  539. session = session.And("HSBY_GOODSEX.DESCCITYID = ?", descCityID)
  540. }
  541. if err := session.Find(&preGoodses); err != nil {
  542. return nil, err
  543. }
  544. // for i := range preGoodses {
  545. // preGoods := &preGoodses[i]
  546. // // FIXME: - 这里应该使用 Duck Typing,后期再处理
  547. // // 计算最小变动单位
  548. // lotSize := float64(preGoods.Quoteminunit) * math.Pow(0.1, float64(preGoods.Decimalplace))
  549. // preGoods.LotSize, _ = strconv.ParseFloat(utils.FormatFloat(lotSize, int(preGoods.Decimalplace)), 64)
  550. // }
  551. return preGoodses, nil
  552. }
  553. // HsbyPreGoodsDetail 一级市场(产能预售)商品信息详情
  554. type HsbyPreGoodsDetail struct {
  555. Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
  556. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  557. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  558. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  559. Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
  560. Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 2:未上市 3:上市
  561. Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
  562. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  563. Listingdate time.Time `json:"listingdate" xorm:"'LISTINGDATE'"` // 交易开始日期
  564. Lasttradedate time.Time `json:"lasttradedate" xorm:"'LASTTRADEDATE'"` // 最后交易日期(状态:待退市)
  565. Relatedgoodsid int64 `json:"relatedgoodsid" xorm:"'RELATEDGOODSID'"` // 关联交易合约ID
  566. Presaleqty int64 `json:"presaleqty" xorm:"'PRESALEQTY'"` // 预售数量
  567. Refprice float64 `json:"refprice" xorm:"'REFPRICE'"` // 参考价格[一口价]
  568. Presaledqty int64 `json:"presaledqty" xorm:"'PRESALEDQTY'"` // 已预售量(预售结束时更新)
  569. EnableQty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 剩余数量
  570. Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
  571. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  572. Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)ID
  573. Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)ID
  574. Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
  575. Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
  576. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  577. Goodunit string `json:"goodunit" xorm:"GOODUNIT"` // 报价单位
  578. Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
  579. Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 供应商客服电话
  580. Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 供应商附件(多张,逗号分隔)
  581. Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  582. Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 发行单位
  583. StepValue float64 `json:"stepvalue" xorm:"-"` // 价格最小变动单位
  584. LotSize int `json:"lotsize" xorm:"-"` // 手数最小变动单位
  585. Buymaxqty int `json:"buymaxqty" xorm:"'-'"` // 购买上限 [71] - 0为不限
  586. }
  587. // GetHsbyPreGoodsDetail 获取一级市场(产能预售)商品信息详情
  588. // 参数 goodsID int 目标商品ID
  589. // 返回 *HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情,查询无结果返回nil
  590. // 返回 error error
  591. func GetHsbyPreGoodsDetail(goodsID, accountID int) (*HsbyPreGoodsDetail, error) {
  592. engine := db.GetEngine()
  593. details := make([]HsbyPreGoodsDetail, 0)
  594. // 获取挂牌商品信息,以及扩展表信息
  595. // FIXME: - 这里使用Get方法,会造成SQL语句的嵌套出错,后期再研究
  596. session := engine.Table("GOODS").
  597. Select(`GOODS.*,
  598. CPTRADE_PRESALEGOODSEX.RELATEDGOODSID, CPTRADE_PRESALEGOODSEX.PRESALEQTY, CPTRADE_PRESALEGOODSEX.REFPRICE,
  599. CPTRADE_PRESALEGOODSEX.PRESALEDQTY, (CPTRADE_PRESALEGOODSEX.PRESALEQTY - CPTRADE_PRESALEGOODSEX.PRESALEDQTY) ENABLEQTY,
  600. HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS, HSBY_GOODSEX.DESCPROVINCEID, HSBY_GOODSEX.Desccityid, HSBY_GOODSEX.Goodsdesc,
  601. ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
  602. E1.ENUMDICNAME GOODUNIT,
  603. HSBY_SUPPLIERINFO.VENDORNAME, HSBY_SUPPLIERINFO.VENDORPHONE, HSBY_SUPPLIERINFO.VENDORATTR,
  604. MARKET.TRADEMODE,
  605. USERINFO.CUSTOMERNAME`).
  606. Join("INNER", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = GOODS.GOODSID").
  607. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
  608. Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
  609. Join("LEFT", "ENUMDICITEM E1", "E1.ENUMITEMNAME = GOODS.GOODUNITID and E1.ENUMDICCODE = 'goodsunit'").
  610. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  611. Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
  612. Join("LEFT", "USERINFO", "USERINFO.USERID = CPTRADE_PRESALEGOODSEX.USERID").
  613. Where("GOODS.GOODSID = ?", goodsID)
  614. if err := session.Find(&details); err != nil {
  615. return nil, err
  616. }
  617. // 无目标商品
  618. if len(details) == 0 {
  619. return nil, nil
  620. }
  621. preGoodsDetail := details[0]
  622. // FIXME: - 这里应该使用 Duck Typing,后期再处理
  623. // 计算价格最小变动单位
  624. stepValue := float64(preGoodsDetail.Quoteminunit) * math.Pow(0.1, float64(preGoodsDetail.Decimalplace))
  625. preGoodsDetail.StepValue, _ = strconv.ParseFloat(utils.FormatFloat(stepValue, int(preGoodsDetail.Decimalplace)), 64)
  626. // 计算手数最小变动单位,一级市场固定为1
  627. preGoodsDetail.LotSize = 1
  628. // 获取购买上限
  629. if accountID != 0 {
  630. buyMaxQty, err := GetCPTradeBuyLimit(goodsID, accountID)
  631. if err != nil {
  632. return nil, err
  633. }
  634. preGoodsDetail.Buymaxqty = buyMaxQty
  635. }
  636. return &preGoodsDetail, nil
  637. }
  638. // HsbySellMyDetail "我的闲置"单据信息(发布中 - 二级市场卖挂,3:委托成功、7:部分成交; 已完成 - 二级市场成交单,包括历史数据)
  639. type HsbySellMyDetail struct {
  640. Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 单号(发布中 - 委托单号;已完成 - 成交单号)
  641. Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
  642. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
  643. Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
  644. Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
  645. Price float64 `json:"price" xorm:"'PRICE'"` // 价格
  646. Qty int64 `json:"qty" xorm:"'QTY'" binding:"required"` // 数量
  647. Time time.Time `json:"time" xorm:"'TIME'" binding:"required"` // 时间
  648. Amount float64 `json:"amount" xorm:"'AMOUNT'"` // 金额 = 价格 * 数量 * 合约单位
  649. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  650. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  651. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  652. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  653. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  654. Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  655. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  656. Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
  657. OrderType int32 `json:"ordertype" xorm:"'ORDERTYPE'"` // 单据类型:0 - 发布中, 1 - 已完成
  658. PayedCount int `json:"payedcount" xorm:"PAYEDCOUNT"` // 已付款数量
  659. UnPayCount int `json:"unPayCount" xorm:"UNPAYCOUNT"` // 待付款数量
  660. }
  661. // GetHsbySellMyOrderDetails 获取"我的闲置 - 发布中"单据信息
  662. // 输入 accountIDs string 资金账户列表
  663. // 输出 []HsbySellMyDetail "我的闲置 - 发布中"单据信息
  664. // 输出 error error
  665. func GetHsbySellMyOrderDetails(accountIDs string) ([]HsbySellMyDetail, error) {
  666. // 获取市场信息
  667. markets, err := GetMarkets()
  668. if err != nil {
  669. return nil, err
  670. }
  671. engine := db.GetEngine()
  672. marketIDs := "" // 我的闲置-发布中: 二级市场卖挂牌
  673. // 默认取 TradeMode = 16
  674. for _, v := range markets {
  675. if v.Trademode == 16 {
  676. if len(marketIDs) == 0 {
  677. marketIDs = strconv.Itoa(int(v.Marketid))
  678. } else {
  679. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  680. }
  681. }
  682. }
  683. orderDetails := make([]HsbySellMyDetail, 0)
  684. // “我的闲置 - 发布中”都是卖挂委托
  685. session := engine.Table("TRADE_ORDERDETAIL").
  686. Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID,
  687. TRADE_ORDERDETAIL.MARKETID, TRADE_ORDERDETAIL.GOODSID, TRADE_ORDERDETAIL.ACCOUNTID, TRADE_ORDERDETAIL.BUYORSELL,
  688. TRADE_ORDERDETAIL.ORDERPRICE PRICE, TRADE_ORDERDETAIL.ORDERQTY QTY, TRADE_ORDERDETAIL.ORDERTIME TIME,
  689. (TRADE_ORDERDETAIL.ORDERPRICE * TRADE_ORDERDETAIL.ORDERQTY * GOODS.AGREEUNIT) AMOUNT,
  690. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  691. HSBY_GOODSEX.PICURLS,
  692. MARKET.TRADEMODE,
  693. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  694. HSBY_SUPPLIERINFO.VENDORNAME,
  695. 0 ORDERTYPE,
  696. (select count(TR1.TRADEID) from TRADE_PAYORDER TR1 where TR1.PAYFLAG = 2 and TR1.TRADEID = TD.TRADEID) PAYEDCOUNT,
  697. (select count(TR2.TRADEID) from TRADE_PAYORDER TR2 where TR2.PAYFLAG = 1 and TR2.TRADEID = TD.TRADEID) UNPAYCOUNT`).
  698. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_ORDERDETAIL.GOODSID").
  699. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  700. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  701. Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_ORDERDETAIL.MARKETID").
  702. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  703. Join("LEFT", "TRADE_TRADEDETAIL TD", "TD.ORDERID = TRADE_ORDERDETAIL.ORDERID").
  704. Where(fmt.Sprintf(`TRADE_ORDERDETAIL.BUYORSELL = 1 and TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 1 and (TRADE_ORDERDETAIL.ORDERSTATUS = 3 or TRADE_ORDERDETAIL.ORDERSTATUS = 7)
  705. and TRADE_ORDERDETAIL.ACCOUNTID in (%s)`, accountIDs)).
  706. And(fmt.Sprintf("TRADE_ORDERDETAIL.MARKETID in (%s)", marketIDs))
  707. if err := session.Find(&orderDetails); err != nil {
  708. return nil, err
  709. }
  710. return orderDetails, nil
  711. }
  712. // GetHsbySellMyTradeDetails 获取"我的闲置 - 已完成"单据信息
  713. // 输入 accountIDs string 资金账户列表
  714. // 输出 []HsbySellMyDetail "我的闲置 - 已完成"单据信息
  715. // 输出 error error
  716. func GetHsbySellMyTradeDetails(accountIDs string) ([]HsbySellMyDetail, error) {
  717. // 获取市场信息
  718. markets, err := GetMarkets()
  719. if err != nil {
  720. return nil, err
  721. }
  722. engine := db.GetEngine()
  723. marketIDs := "" // 我的闲置-发布中: 二级市场卖方向成交单(包括历史成交单)
  724. // 默认取 TradeMode = 16
  725. for _, v := range markets {
  726. if v.Trademode == 16 {
  727. if len(marketIDs) == 0 {
  728. marketIDs = strconv.Itoa(int(v.Marketid))
  729. } else {
  730. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  731. }
  732. }
  733. }
  734. orders := make([]HsbySellMyDetail, 0)
  735. // 当前成交单
  736. curOrders := make([]HsbySellMyDetail, 0)
  737. if err := engine.Table("TRADE_TRADEDETAIL").
  738. Select(`to_char(TRADE_TRADEDETAIL.TRADEID) ORDERID,
  739. TRADE_TRADEDETAIL.MARKETID, TRADE_TRADEDETAIL.GOODSID, TRADE_TRADEDETAIL.ACCOUNTID, TRADE_TRADEDETAIL.BUYORSELL,
  740. TRADE_TRADEDETAIL.TRADEPRICE PRICE, TRADE_TRADEDETAIL.TRADEQTY QTY, TRADE_TRADEDETAIL.TRADETIME TIME, TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
  741. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  742. HSBY_GOODSEX.PICURLS,
  743. MARKET.TRADEMODE,
  744. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  745. HSBY_SUPPLIERINFO.VENDORNAME,
  746. 1 ORDERTYPE`).
  747. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_TRADEDETAIL.GOODSID").
  748. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  749. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  750. Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_TRADEDETAIL.MARKETID").
  751. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  752. Where(fmt.Sprintf(`TRADE_TRADEDETAIL.BUYORSELL = 1
  753. and TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
  754. And(fmt.Sprintf("TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&curOrders); err != nil {
  755. return nil, err
  756. }
  757. if len(curOrders) > 0 {
  758. orders = append(orders, curOrders...)
  759. }
  760. // 历史成交单
  761. hisOrders := make([]HsbySellMyDetail, 0)
  762. if err := engine.Table("HIS_TRADE_TRADEDETAIL").
  763. Select(`to_char(HIS_TRADE_TRADEDETAIL.TRADEID) ORDERID,
  764. HIS_TRADE_TRADEDETAIL.MARKETID, HIS_TRADE_TRADEDETAIL.GOODSID, HIS_TRADE_TRADEDETAIL.ACCOUNTID, HIS_TRADE_TRADEDETAIL.BUYORSELL,
  765. HIS_TRADE_TRADEDETAIL.TRADEPRICE PRICE, HIS_TRADE_TRADEDETAIL.TRADEQTY QTY, HIS_TRADE_TRADEDETAIL.TRADETIME TIME, HIS_TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
  766. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  767. HSBY_GOODSEX.PICURLS,
  768. MARKET.TRADEMODE,
  769. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  770. HSBY_SUPPLIERINFO.VENDORNAME,
  771. 1 ORDERTYPE`).
  772. Join("LEFT", "GOODS", "GOODS.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
  773. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  774. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  775. Join("LEFT", "MARKET", "MARKET.MARKETID = HIS_TRADE_TRADEDETAIL.MARKETID").
  776. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  777. Where(fmt.Sprintf(`HIS_TRADE_TRADEDETAIL.BUYORSELL = 1 and HIS_TRADE_TRADEDETAIL.ISVALIDDATA = 1
  778. and HIS_TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
  779. And(fmt.Sprintf("HIS_TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&hisOrders); err != nil {
  780. return nil, err
  781. }
  782. if len(hisOrders) > 0 {
  783. orders = append(orders, hisOrders...)
  784. }
  785. return orders, nil
  786. }
  787. // HsbyMyPackage 我的包裹信息
  788. type HsbyMyPackage struct {
  789. Takeorderid string `json:"takeorderid" xorm:"'TAKEORDERID'" binding:"required"` // 提货单号(905+Unix秒时间戳(10位)+xxxxxx)
  790. Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'"` // 账户ID
  791. Goodsid int64 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
  792. Userid int64 `json:"userid" xorm:"'USERID'"` // 用户ID
  793. Qty float64 `json:"qty" xorm:"'QTY'"` // 提货数量
  794. Reqtime time.Time `json:"reqtime" xorm:"'REQTIME'"` // 更新时间
  795. Recivername string `json:"recivername" xorm:"'RECIVERNAME'"` // 提货人姓名
  796. Cardtypeid int32 `json:"cardtypeid" xorm:"'CARDTYPEID'"` // 提货人证件类型
  797. Cardnum string `json:"cardnum" xorm:"'CARDNUM'"` // 提货人证件号码
  798. Phonenum string `json:"phonenum" xorm:"'PHONENUM'"` // 提货人联系方式
  799. Takemode int32 `json:"takemode" xorm:"'TAKEMODE'"` // 提货方式 - 2:自提 3:配送
  800. Address string `json:"address" xorm:"'ADDRESS'"` // 提货人详细地址
  801. Takeremark string `json:"takeremark" xorm:"'TAKEREMARK'"` // 提货备注
  802. Takeorderstatus int32 `json:"takeorderstatus" xorm:"'TAKEORDERSTATUS'"` // 提货状态 - 1:待发货 2:已发货 3:已收货
  803. Auditer int32 `json:"auditer" xorm:"'AUDITER'"` // 审核人
  804. Audittime time.Time `json:"audittime" xorm:"'AUDITTIME'"` // 审核时间
  805. Checkremark string `json:"checkremark" xorm:"'CHECKREMARK'"` // 审核备注
  806. Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
  807. Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
  808. Handlestatus int32 `json:"handlestatus" xorm:"'HANDLESTATUS'"` // 处理状态
  809. Amount float64 `json:"amount" xorm:"'AMOUNT'"` // 提货金额
  810. Averageprice float64 `json:"averageprice" xorm:"'AVERAGEPRICE'"` // 均价
  811. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  812. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  813. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  814. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  815. Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
  816. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  817. Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
  818. }
  819. // GetHsbyMyPackages 获取我的包裹信息
  820. // 输入 accountIDs string 资金账户列表
  821. // 输入 takeOrderStatus int 提货状态 - 1:待发货 2:已发货 3:已收货
  822. // 输出 []HsbyMyPackage 我的包裹信息
  823. // 输出 error error
  824. func GetHsbyMyPackages(accountIDs string, takeOrderStatus int) ([]HsbyMyPackage, error) {
  825. engine := db.GetEngine()
  826. myPackages := make([]HsbyMyPackage, 0)
  827. session := engine.Table("TRADE_GOODSPICKUP").
  828. Select(`to_char(TRADE_GOODSPICKUP.TAKEORDERID) TAKEORDERID, (DIVISION.PATHNAME || TRADE_GOODSPICKUP.ADDRESS) ADDRESS, TRADE_GOODSPICKUP.*,
  829. (TRADE_GOODSPICKUP.AMOUNT/TRADE_GOODSPICKUP.QTY/GOODS.AGREEUNIT) AVERAGEPRICE,
  830. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  831. HSBY_GOODSEX.PICURLS,
  832. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  833. HSBY_SUPPLIERINFO.VENDORNAME`).
  834. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_GOODSPICKUP.GOODSID").
  835. Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
  836. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  837. Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
  838. Join("LEFT", "DIVISION", "DIVISION.AUTOID = TRADE_GOODSPICKUP.DISTRICTID").
  839. Where(fmt.Sprintf("TRADE_GOODSPICKUP.ACCOUNTID in (%s)", accountIDs))
  840. if takeOrderStatus > 0 {
  841. session = session.And("TAKEORDERSTATUS = ?", takeOrderStatus)
  842. }
  843. if err := session.Find(&myPackages); err != nil {
  844. return nil, err
  845. }
  846. // FIXME:- 目前暂时在服务端对手机号码进行解密
  847. key, _ := hex.DecodeString(utils.AESSecretKey)
  848. for i := range myPackages {
  849. myPackage := &myPackages[i]
  850. // 解密手机号码
  851. if phonenum, err := hex.DecodeString(myPackage.Phonenum); err == nil { // hex -> []byte
  852. if mobile, err := utils.AESDecrypt(phonenum, key); err == nil {
  853. myPackage.Phonenum = string(mobile)
  854. }
  855. }
  856. }
  857. return myPackages, nil
  858. }
  859. // SetHsbyMyPackagesStatus 设置我的包裹提货状态
  860. func SetHsbyMyPackagesStatus(takeOrderID string, accountID, status int) error {
  861. engine := db.GetEngine()
  862. sql := fmt.Sprintf("update TRADE_GOODSPICKUP set TAKEORDERSTATUS = %d where TAKEORDERID = %s and ACCOUNTID = %d", status, takeOrderID, accountID)
  863. _, err := engine.Exec(sql)
  864. return err
  865. }
  866. // GetHsbyProvincesAndCities 获取省市信息数组
  867. // 参数 provinceID int 省ID,选填
  868. // 返回 []Division 枚举信息数组
  869. // 返回 error error
  870. func GetHsbyProvincesAndCities(provinceID int) ([]Division, error) {
  871. engine := db.GetEngine()
  872. divisions := make([]Division, 0)
  873. session := engine.Where("DIVISIONLEVEL = 'province' or DIVISIONLEVEL = 'city'").
  874. And(`AUTOID in (
  875. (select DESCPROVINCEID AUTOID from HSBY_GOODSEX inner join GOODS on GOODS.GOODSID = HSBY_GOODSEX.GOODSID and GOODS.GOODSSTATUS in (2,3))
  876. union all
  877. (select DESCCITYID AUTOID from HSBY_GOODSEX inner join GOODS on GOODS.GOODSID = HSBY_GOODSEX.GOODSID and GOODS.GOODSSTATUS in (2,3))
  878. )`)
  879. if provinceID > 0 {
  880. session = session.And("AUTOID = ?", provinceID)
  881. }
  882. if err := session.Find(&divisions); err != nil {
  883. return nil, err
  884. }
  885. return divisions, nil
  886. }
  887. // HsbyBuyMyTradeDetail "我的订单 - 已完成"单据信息(一二级市场成交单,包括历史数据)
  888. type HsbyBuyMyTradeDetail struct {
  889. Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 单号(成交单号)
  890. Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
  891. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
  892. Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
  893. Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
  894. Price float64 `json:"price" xorm:"'PRICE'"` // 价格
  895. Qty int64 `json:"qty" xorm:"'QTY'" binding:"required"` // 数量
  896. Time time.Time `json:"time" xorm:"'TIME'" binding:"required"` // 时间
  897. Amount float64 `json:"amount" xorm:"'AMOUNT'"` // 金额 = 价格 * 数量 * 合约单位
  898. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  899. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  900. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  901. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  902. Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
  903. Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
  904. Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  905. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  906. Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
  907. Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
  908. }
  909. // GetHsbyBuyMyTradeDetails 获取"我的订单 - 已完成"单据信息(一二级市场成交单,包括历史数据)
  910. // 输入 accountIDs string 资金账户列表
  911. // 输出 []HsbyBuyMyTradeDetail "我的订单 - 已完成"单据信息
  912. // 输出 error error
  913. func GetHsbyBuyMyTradeDetails(accountIDs string) ([]HsbyBuyMyTradeDetail, error) {
  914. // 获取市场信息
  915. markets, err := GetMarkets()
  916. if err != nil {
  917. return nil, err
  918. }
  919. engine := db.GetEngine()
  920. marketIDs := "" // 我的订单包括一二级市场卖方向成交单(包括历史成交单)
  921. // 默认取 TradeMode = 16
  922. for _, v := range markets {
  923. if v.Trademode == 16 || v.Trademode == 71 {
  924. if len(marketIDs) == 0 {
  925. marketIDs = strconv.Itoa(int(v.Marketid))
  926. } else {
  927. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  928. }
  929. }
  930. }
  931. orders := make([]HsbyBuyMyTradeDetail, 0)
  932. // 当前成交单
  933. curOrders := make([]HsbyBuyMyTradeDetail, 0)
  934. if err := engine.Table("TRADE_TRADEDETAIL").
  935. Select(`to_char(TRADE_TRADEDETAIL.TRADEID) ORDERID,
  936. TRADE_TRADEDETAIL.MARKETID, TRADE_TRADEDETAIL.GOODSID, TRADE_TRADEDETAIL.ACCOUNTID, TRADE_TRADEDETAIL.BUYORSELL,
  937. TRADE_TRADEDETAIL.TRADEPRICE PRICE, TRADE_TRADEDETAIL.TRADEQTY QTY, TRADE_TRADEDETAIL.TRADETIME TIME, TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
  938. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  939. HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
  940. MARKET.TRADEMODE,
  941. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  942. HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
  943. Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_TRADEDETAIL.GOODSID").
  944. Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = TRADE_TRADEDETAIL.GOODSID").
  945. Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
  946. Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
  947. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  948. Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_TRADEDETAIL.MARKETID").
  949. Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
  950. Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
  951. Where(fmt.Sprintf(`TRADE_TRADEDETAIL.BUYORSELL = 0
  952. and TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
  953. And(fmt.Sprintf("TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&curOrders); err != nil {
  954. return nil, err
  955. }
  956. if len(curOrders) > 0 {
  957. orders = append(orders, curOrders...)
  958. }
  959. // 历史成交单
  960. hisOrders := make([]HsbyBuyMyTradeDetail, 0)
  961. if err := engine.Table("HIS_TRADE_TRADEDETAIL").
  962. Select(`to_char(HIS_TRADE_TRADEDETAIL.TRADEID) ORDERID,
  963. HIS_TRADE_TRADEDETAIL.MARKETID, HIS_TRADE_TRADEDETAIL.GOODSID, HIS_TRADE_TRADEDETAIL.ACCOUNTID, HIS_TRADE_TRADEDETAIL.BUYORSELL,
  964. HIS_TRADE_TRADEDETAIL.TRADEPRICE PRICE, HIS_TRADE_TRADEDETAIL.TRADEQTY QTY, HIS_TRADE_TRADEDETAIL.TRADETIME TIME, HIS_TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
  965. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  966. HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
  967. MARKET.TRADEMODE,
  968. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  969. HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
  970. Join("LEFT", "GOODS", "GOODS.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
  971. Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
  972. Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
  973. Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
  974. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  975. Join("LEFT", "MARKET", "MARKET.MARKETID = HIS_TRADE_TRADEDETAIL.MARKETID").
  976. Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
  977. Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
  978. Where(fmt.Sprintf(`HIS_TRADE_TRADEDETAIL.BUYORSELL = 0 and HIS_TRADE_TRADEDETAIL.ISVALIDDATA = 1
  979. and HIS_TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
  980. And(fmt.Sprintf("HIS_TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&hisOrders); err != nil {
  981. return nil, err
  982. }
  983. if len(hisOrders) > 0 {
  984. orders = append(orders, hisOrders...)
  985. }
  986. return orders, nil
  987. }
  988. // HsbyBuyMyPayOrder "我的订单 - 待付款"单据信息(一二级市场成交单和待付款信息)
  989. type HsbyBuyMyPayOrder struct {
  990. Tradeid string `json:"tradeid" xorm:"'TRADEIDSTR'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  991. Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
  992. Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
  993. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
  994. Buyorderid string `json:"buyorderid" xorm:"'BUYORDERIDSTR'"` // 买方委托单号
  995. Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
  996. Sellorderid string `json:"sellorderid" xorm:"'SELLORDERIDSTR'"` // 卖方委托单号
  997. Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
  998. Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
  999. Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
  1000. Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
  1001. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  1002. Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
  1003. Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
  1004. Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
  1005. Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
  1006. Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
  1007. Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
  1008. Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
  1009. Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
  1010. Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
  1011. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  1012. Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
  1013. Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
  1014. Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  1015. Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
  1016. Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
  1017. Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
  1018. }
  1019. // GetHsbyBuyMyPayOrders 获取待付款信息
  1020. func GetHsbyBuyMyPayOrders(accountIDs string, buyOrderID, sellOrderID int) ([]HsbyBuyMyPayOrder, error) {
  1021. // 获取市场信息
  1022. markets, err := GetMarkets()
  1023. if err != nil {
  1024. return nil, err
  1025. }
  1026. engine := db.GetEngine()
  1027. marketIDs := "" // 我的订单包括一二级市场卖方向成交单
  1028. // 默认取 TradeMode = 16
  1029. for _, v := range markets {
  1030. if v.Trademode == 16 || v.Trademode == 71 {
  1031. if len(marketIDs) == 0 {
  1032. marketIDs = strconv.Itoa(int(v.Marketid))
  1033. } else {
  1034. marketIDs += "," + strconv.Itoa(int(v.Marketid))
  1035. }
  1036. }
  1037. }
  1038. orders := make([]HsbyBuyMyPayOrder, 0)
  1039. session := engine.Table("TRADE_PAYORDER TP").
  1040. Select(`to_char(TP.TRADEID) TRADEIDSTR, to_char(TP.BUYORDERID) BUYORDERIDSTR, to_char(TP.SELLORDERID) SELLORDERIDSTR, TP.*,
  1041. GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
  1042. HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
  1043. MARKET.TRADEMODE,
  1044. ENUMDICITEM.PARAM2 CURRENCYSIGN,
  1045. HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
  1046. Join("LEFT", "GOODS", "GOODS.GOODSID = TP.GOODSID").
  1047. Join("LEFT", "CPTRADE_PRESALEGOODSEX CP", "CP.GOODSID = TP.GOODSID").
  1048. Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CP.RELATEDGOODSID").
  1049. Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
  1050. Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
  1051. Join("LEFT", "MARKET", "MARKET.MARKETID = TP.MARKETID").
  1052. Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
  1053. Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
  1054. Where(fmt.Sprintf(`TP.PAYFLAG = 1 and TP.BUYACCOUNTID in (%s)`, accountIDs)).
  1055. And(fmt.Sprintf("TP.MARKETID in (%s)", marketIDs))
  1056. if buyOrderID != 0 {
  1057. session = session.And("TP.BUYORDERID = ?", buyOrderID)
  1058. }
  1059. if sellOrderID != 0 {
  1060. session = session.And("TP.SELLORDERID = ?", sellOrderID)
  1061. }
  1062. if err := session.Find(&orders); err != nil {
  1063. return nil, err
  1064. }
  1065. return orders, nil
  1066. }
  1067. // HsbyMarketInfo 海商报业相关市场信息
  1068. type HsbyMarketInfo struct {
  1069. Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID正常5位,前三位固定:两位表示交易模式, 一位表示交易属性(1:收益权,2:所有权) 其它特殊市场:0-系统 1-交割服务 2-账户服务3-履约服务 4-仓单服务 5-积分服务 6-银行服务
  1070. Marketname string `json:"marketname" xorm:"'MARKETNAME'"` // 市场名称
  1071. Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
  1072. }
  1073. // GetHsbyMarketInfos 获取海商报业相关市场信息
  1074. func GetHsbyMarketInfos() ([]HsbyMarketInfo, error) {
  1075. engine := db.GetEngine()
  1076. markets := make([]HsbyMarketInfo, 0)
  1077. if err := engine.Table("MARKET").Where("TRADEMODE in (71,16,70)").Find(&markets); err != nil {
  1078. return nil, err
  1079. }
  1080. return markets, nil
  1081. }
  1082. // HsbySellCollectionOrder 我的闲置中收款信息
  1083. type HsbySellCollectionOrder struct {
  1084. Tradeid string `json:"tradeid" xorm:"'TRADEIDSTR'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  1085. Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
  1086. Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
  1087. Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
  1088. Buyorderid string `json:"buyorderid" xorm:"'BUYORDERIDSTR'"` // 买方委托单号
  1089. Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
  1090. Sellorderid string `json:"sellorderid" xorm:"'SELLORDERIDSTR'"` // 卖方委托单号
  1091. Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
  1092. Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
  1093. Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
  1094. Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
  1095. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  1096. Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
  1097. Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
  1098. Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
  1099. Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
  1100. Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
  1101. Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
  1102. Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 客户名称(企业名称),已脱敏
  1103. Currencysign string `json:"currencysign" xorm:"CURRENCYSIGN"` // 货币符号
  1104. Goodunit string `json:"goodunit" xorm:"GOODUNIT"` // 报价单位
  1105. Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
  1106. }
  1107. // GetHsbySellCollectionOrders 获取我的闲置中收款信息
  1108. func GetHsbySellCollectionOrders(sellOrderID, sellAccountID int) ([]HsbySellCollectionOrder, error) {
  1109. engine := db.GetEngine()
  1110. orders := make([]HsbySellCollectionOrder, 0)
  1111. if err := engine.Table("TRADE_PAYORDER TP").
  1112. Select(`to_char(TP.TRADEID) TRADEIDSTR, to_char(TP.BUYORDERID) BUYORDERIDSTR, to_char(TP.SELLORDERID) SELLORDERIDSTR, TP.*,
  1113. substr(U.CUSTOMERNAME,0,1)||'****' as CUSTOMERNAME,
  1114. E1.PARAM2 CURRENCYSIGN,
  1115. E1.ENUMDICNAME GOODUNIT,
  1116. G.AGREEUNIT`).
  1117. Join("LEFT", "TAACCOUNT TA", "TA.ACCOUNTID = TP.SELLACCOUNTID").
  1118. Join("LEFT", "USERINFO U", "U.USERID = TA.RELATEDUSERID").
  1119. Join("LEFT", "GOODS G", "G.GOODSID = TP.GOODSID").
  1120. Join("LEFT", "ENUMDICITEM E1", "E1.ENUMITEMNAME = G.CURRENCYID and E1.ENUMDICCODE = 'currency'").
  1121. Join("LEFT", "ENUMDICITEM E2", "E2.ENUMITEMNAME = G.GOODUNITID and E2.ENUMDICCODE = 'goodsunit'").
  1122. Where("TP.PAYFLAG in (1,2) and TP.SELLORDERID = ?", sellOrderID).
  1123. And("TP.SELLACCOUNTID = ?", sellAccountID).
  1124. Find(&orders); err != nil {
  1125. return nil, err
  1126. }
  1127. return orders, nil
  1128. }