qhjPCWeb.go 63 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136
  1. /**
  2. * @Author: zou.yingbin
  3. * @Create : 2021/6/24 10:07
  4. * @Modify : 2021/6/24 10:07
  5. */
  6. package models
  7. import (
  8. "fmt"
  9. "mtp2_if/db"
  10. "mtp2_if/mtpcache"
  11. "mtp2_if/utils"
  12. )
  13. // QhjMgrSubArea 子机构列表
  14. type QhjMgrSubArea struct {
  15. PARENTTOPUSER string `json:"parenttopuser" xorm:"PARENTTOPUSER"` // 上级顶级机构 [092=0,1时,默认为1, 092=2时若自已为顶级,则填入自己,自己不为顶级,填入ParentUserID的"ParentTopUser"]
  16. SUBACCOUNTLEVEL int32 `json:"subaccountlevel" xorm:"SUBACCOUNTLEVEL"` // 子账户层数
  17. ROOTUSERID string `json:"rootuserid" xorm:"ROOTUSERID"` // 根用户ID
  18. USERID int64 `json:"userid" xorm:"USERID"` // 用户ID
  19. USERTYPE int32 `json:"usertype" xorm:"USERTYPE"` // 账户类型 - 1:交易所 2:机构 3:会员子机构 4:经纪人 5:投资者 6:客户 7:企业成员(云平台)
  20. ACCOUNTNAME string `json:"accountname" xorm:"ACCOUNTNAME"` // 账户名称(机构名称)
  21. PARENTUSERID int64 `json:"parentuserid" xorm:"PARENTUSERID"` // 所属机构ID
  22. SUBAREALEVELPATH string `json:"subarealevelpath" xorm:"SUBAREALEVELPATH"` // 子机构层级路径(逗号分隔,首尾加逗号)
  23. MEMBERUSERID int64 `json:"memberuserid" xorm:"MEMBERUSERID"` // 所属会员ID
  24. }
  25. func (r *QhjMgrSubArea) calc() {
  26. }
  27. func (r *QhjMgrSubArea) buildSql() string {
  28. var sqlId utils.SQLVal = "select t.userid," +
  29. " t.accountname," +
  30. " t.parentuserid," +
  31. " t.rootuserid," +
  32. " t.memberuserid," +
  33. " t.parenttopuser," +
  34. " t.subarealevelpath," +
  35. " t.subaccountlevel," +
  36. " t.usertype" +
  37. " from useraccount t" +
  38. " where 1 = 1"
  39. sqlId.And("t.usertype", 2)
  40. sqlId.Join(fmt.Sprintf("and t.userid != %v", r.USERID))
  41. sqlId.Join(fmt.Sprintf(" and t.subarealevelpath like ',%%%v%%,'", r.USERID))
  42. return sqlId.String()
  43. }
  44. // GetDataEx 获取子机构列表
  45. func (r *QhjMgrSubArea) GetDataEx() (interface{}, error) {
  46. sData := make([]QhjMgrSubArea, 0)
  47. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  48. for i := range sData {
  49. sData[i].calc()
  50. }
  51. return sData, err
  52. }
  53. // QhjMgrCustomer 客户资料
  54. type QhjMgrCustomer struct {
  55. USERID int64 `json:"userid" xorm:"'USERID'"` // 用户ID
  56. MEMBERUSERID int64 `json:"memberuserid" xorm:"'MEMBERUSERID'"` // 所属机构ID(所属会员)
  57. PARENTUSERID int64 `json:"parentuserid" xorm:"'PARENTUSERID'"` // 上级机构(所属机构)
  58. USERINFOTYPE int32 `json:"userinfotype" xorm:"'USERINFOTYPE'"` // 客户类型 1-个人 2-企业
  59. CUSTOMERNAME string `json:"customername" xorm:"'CUSTOMERNAME'"` // 客户名称
  60. CARDTYPE int32 `json:"cardtype" xorm:"'CARDTYPE'"` // 证件类型
  61. CARDNUM string `json:"cardnum" xorm:"'CARDNUM'"` // 证件号码
  62. MOBILE string `json:"mobile" xorm:"'MOBILE'"` // 手机号码
  63. TELPHONE string `json:"telphone" xorm:"'TELPHONE'"` // 联系电话
  64. ADDRESS string `json:"address" xorm:"'ADDRESS'"` // 通讯地址
  65. REMARK string `json:"remark" xorm:"'REMARK'"` // 备注
  66. STATUS int32 `json:"status" xorm:"'STATUS'"` // 账户状态 - 1:待激活 2:待审核 3:待复审 4:正常 5:审核拒绝 6:注销
  67. STATUSDESC string `json:"statusdesc"` // 账户状态中文描述
  68. ATTACHMENT1 string `json:"attachment1" xorm:"'ATTACHMENT1'"` // 附件1
  69. CARDFRONTPHOTOURL string `json:"cardfrontphotourl" xorm:"'CARDFRONTPHOTOURL'"` // 证件正面图片地址
  70. CARDBACKPHOTOURL string `json:"cardbackphotourl" xorm:"'CARDBACKPHOTOURL'"` // 证件反面图片地址
  71. COUNTRYID int32 `json:"countryid" xorm:"'COUNTRYID'"` // 国家
  72. PROVINCEID int32 `json:"provinceid" xorm:"'PROVINCEID'"` // 省
  73. CITYID int32 `json:"cityid" xorm:"'CITYID'"` // 市
  74. DISTRICTID int32 `json:"districtid" xorm:"'DISTRICTID'"` // 区域
  75. CREATETIME string `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  76. MODIFYTIME string `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  77. AUDITTIME string `json:"audittime" xorm:"'AUDITTIME'"` // 审核时间
  78. NICKNAME string `json:"nickname" xorm:"'NICKNAME'"` // 昵称
  79. TAXPAYERNUM string `json:"taxpayernum" xorm:"'taxpayernum'"` // 纳税人识别号
  80. LEGALPERSONNAME string `json:"legalpersonname" xorm:"'legalpersonname'"` // 法人姓名(企业)
  81. CONTACTNAME string `json:"contactname" xorm:"'contactname'"` // 联系人
  82. EMAIL string `json:"email" xorm:"'EMAIL'"` // 邮件
  83. USERNAME string `json:"username" xorm:"'USERNAME'"` // 用户名称
  84. LOGINCODE string `json:"logincode" xorm:"'LOGINCODE'"` // 登录账号(代码)
  85. COUNTRYNAME string `json:"countryname"` // 国家名称
  86. CITYNAME string `json:"cityname"` // 城市名称
  87. PROVINCENAME string `json:"provincename"` // 省名称
  88. DISTRICTNAME string `json:"districtname"` // 地区名称
  89. CARDTYPENAME string `json:"cardtypename"` // 证件类型名称
  90. MEMBERUSERNAME string `json:"memberusername"` // 所属会员名称
  91. PARENTUSERNAME string `json:"parentusername"` //所属机构名称
  92. QUERYTYPE int32 `json:"-"` // 查询类型(1:未提交(网上开户表) 2:待审核(网上开户表) 3:正常 4:停用)
  93. IncludeSub int32 `json:"-"` // 包子机构客户 1-包含
  94. }
  95. func (r *QhjMgrCustomer) calc() {
  96. r.MEMBERUSERNAME = mtpcache.GetUserNameByUserId(r.MEMBERUSERID)
  97. if len(r.USERNAME) == 0 {
  98. r.USERNAME = mtpcache.GetUserNameByUserId(r.USERID)
  99. }
  100. r.PARENTUSERNAME = mtpcache.GetUserNameByUserId(r.PARENTUSERID)
  101. r.COUNTRYNAME = mtpcache.GetDivisionName(r.COUNTRYID)
  102. r.CITYNAME = mtpcache.GetDivisionName(r.CITYID)
  103. r.PROVINCENAME = mtpcache.GetDivisionName(r.PROVINCEID)
  104. r.DISTRICTNAME = mtpcache.GetDivisionName(r.DISTRICTID)
  105. switch r.QUERYTYPE {
  106. case 1, 2: // 网上开户表
  107. r.ADDRESS = DecryptField(r.ADDRESS)
  108. r.TELPHONE = DecryptField(r.TELPHONE)
  109. case 3, 4: // 正式表
  110. r.TELPHONE = DecryptField(r.TELPHONE)
  111. }
  112. r.CARDNUM = DecryptField(r.CARDNUM)
  113. r.MOBILE = DecryptField(r.MOBILE)
  114. r.EMAIL = DecryptField(r.EMAIL)
  115. if r.LOGINCODE == "" {
  116. r.LOGINCODE = r.MOBILE
  117. }
  118. }
  119. func (r *QhjMgrCustomer) level() int32 {
  120. if r.IncludeSub > 0 {
  121. // 层级, 最多20层
  122. return 20
  123. }
  124. return 1
  125. }
  126. func (r *QhjMgrCustomer) buildSql() string {
  127. if r.QUERYTYPE == 1 || r.QUERYTYPE == 2 {
  128. return r.buildSqlWskh()
  129. }
  130. return r.buildSqlNormal()
  131. }
  132. func (r *QhjMgrCustomer) buildSqlWskh() string {
  133. var sqlId utils.SQLVal = "select *" +
  134. " from (select t.userid," +
  135. " t.memberareaid MEMBERUSERID," +
  136. " t.USERINFOTYPE," +
  137. " t.username," +
  138. " t.CUSTOMERNAME," +
  139. " t.NICKNAME," +
  140. " t.CARDTYPE," +
  141. " t.CARDNUM," +
  142. " t.mobilephone MOBILE," +
  143. " t.TELPHONE," +
  144. " t.cardaddress ADDRESS," +
  145. " t.REMARK," +
  146. " t.ATTACHMENT1," +
  147. " t.CARDFRONTPHOTOURL," +
  148. " t.CARDBACKPHOTOURL," +
  149. " t.userstate status," +
  150. " t.countryid," +
  151. " t.provinceid," +
  152. " t.districtid," +
  153. " to_char(t.createtime, 'yyyy-mm-dd hh24:mi:ss') createtime," +
  154. " t.cityid," +
  155. " to_char(t.modifiedtime, 'yyyy-mm-dd hh24:mi:ss') modifytime," +
  156. " to_char(t.auditime, 'yyyy-mm-dd hh24:mi:ss') audittime," +
  157. " t.taxpayernum," +
  158. " t.legalpersonname," +
  159. " t.contactname," +
  160. " t.email," +
  161. " t.areaid parentuserid," +
  162. " t.logincode," +
  163. " t.usertype" +
  164. " from wskh_userinfo t" +
  165. " start with t.areaid = %v" +
  166. " connect by prior t.userid = t.areaid" +
  167. " and t.usertype in (2, 6)" +
  168. " and level = %v) a" +
  169. " where 1 = 1" +
  170. " and a.usertype != 2" +
  171. " and a.status in (%v)"
  172. status := DecodeStr(r.QUERYTYPE == 1, "1", "2,4,5")
  173. sqlId.FormatParam(r.USERID, r.level(), status)
  174. sqlId.AndEx("a.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  175. sqlId.JoinEx(len(r.CUSTOMERNAME) > 0, fmt.Sprintf(` and a.customername like '%%%v%%'`, r.CUSTOMERNAME))
  176. sqlId.JoinEx(len(r.NICKNAME) > 0, fmt.Sprintf(` and a.nickname like '%%%v%%'`, r.NICKNAME))
  177. return sqlId.String()
  178. }
  179. func (r *QhjMgrCustomer) buildSqlNormal() string {
  180. var sqlId utils.SQLVal = "with tmp as" +
  181. " (select t.userid, wm_concat(t.logincode) logincode" +
  182. " from loginaccount t" +
  183. " group by t.userid)" +
  184. "select a.*," +
  185. " k.logincode," +
  186. " u.USERINFOTYPE," +
  187. " u.CUSTOMERNAME," +
  188. " u.NICKNAME," +
  189. " u.CARDTYPEID CARDTYPE," +
  190. " u.CARDNUM," +
  191. " u.MOBILE," +
  192. " u.TELPHONE," +
  193. " u.ADDRESS," +
  194. " u.REMARK," +
  195. " u.ATTACHMENT1," +
  196. " u.CARDFRONTPHOTOURL," +
  197. " u.CARDBACKPHOTOURL," +
  198. " u.countryid," +
  199. " u.provinceid," +
  200. " u.districtid," +
  201. " u.taxpayernum," +
  202. " u.legalpersonname," +
  203. " u.contactname," +
  204. " u.email," +
  205. " u.cityid" +
  206. " from (select t.userid," +
  207. " t.usertype," +
  208. " t.parentuserid," +
  209. " t.memberuserid," +
  210. " t.accountstatus status," +
  211. " to_char(t.createtime, 'yyyy-mm-dd hh24:mi:ss') createtime," +
  212. " to_char(t.modifytime, 'yyyy-mm-dd hh24:mi:ss') modifytime," +
  213. " to_char(t.audittime, 'yyyy-mm-dd hh24:mi:ss') audittime" +
  214. " from useraccount t where 1=1 and t.usertype = 6 %v" +
  215. " ) a" +
  216. " left join tmp k" +
  217. " on a.userid = k.userid" +
  218. " left join userinfo u" +
  219. " on a.userid = u.userid" +
  220. " where 1 = 1"
  221. status := DecodeStr(r.QUERYTYPE == 3, "4", "6")
  222. var sqlParam utils.SQLVal
  223. sqlParam.And("t.accountstatus", status)
  224. if r.IncludeSub == 1 {
  225. sqlParam.Join(fmt.Sprintf(" and t.subarealevelpath like '%%,%v,%%'", r.USERID))
  226. } else {
  227. sqlParam.And("t.parentuserid", r.USERID)
  228. }
  229. sqlId.FormatParam(sqlParam.String())
  230. sqlId.AndEx("u.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  231. sqlId.JoinEx(len(r.CUSTOMERNAME) > 0, fmt.Sprintf(` and u.customername like '%%%v%%'`, r.CUSTOMERNAME))
  232. sqlId.JoinEx(len(r.NICKNAME) > 0, fmt.Sprintf(` and u.nickname like '%%%v%%'`, r.NICKNAME))
  233. return sqlId.String()
  234. }
  235. // GetDataEx 获取客户资料
  236. func (r *QhjMgrCustomer) GetDataEx() (interface{}, error) {
  237. sData := make([]QhjMgrCustomer, 0)
  238. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  239. for i := range sData {
  240. sData[i].QUERYTYPE = r.QUERYTYPE
  241. sData[i].calc()
  242. }
  243. return sData, err
  244. }
  245. // QhjMgrAccountOutInApply 充值提现(出入金)
  246. type QhjMgrAccountOutInApply struct {
  247. EXECUTETYPE int32 `json:"executetype" xorm:"EXECUTETYPE"` // 申请类型 - 1:出金 2:入金 3: 单边账调整:入金; 4:单边账调整:出金 5:外部母账户调整:入金 6:外部母账户调整:出金 7:外部子账户:入金 8:外部子账户:出金
  248. AMOUNT float64 `json:"amount" xorm:"AMOUNT"` // 金额
  249. CURRENCY string `json:"currency" xorm:"CURRENCY"` // 币种
  250. CHARGE float64 `json:"charge" xorm:"CHARGE"` // 手续费
  251. ACCOUNTPWD string `json:"accountpwd" xorm:"ACCOUNTPWD"` // 资金密码
  252. UPDATETIME string `json:"updatetime" xorm:"UPDATETIME"` // 更新时间(申请时间)
  253. BANKID string `json:"bankid" xorm:"BANKID"` // 银行编号
  254. BANKNAME string `json:"bankname" xorm:"'BANKNAME'"` // 银行名称
  255. BRANCHBANKID string `json:"branchbankid" xorm:"BRANCHBANKID"` // 银行支行号
  256. BRANCHBANKNAME string `json:"branchbankname" xorm:"BRANCHBANKNAME"` // 银行支行名称
  257. BANKACCOUNTNO string `json:"bankaccountno" xorm:"BANKACCOUNTNO"` // 银行卡号
  258. BANKACCOUNTNAME string `json:"bankaccountname" xorm:"BANKACCOUNTNAME"` // 银行账户名
  259. EXTENDINFO string `json:"extendinfo" xorm:"EXTENDINFO"` // 扩展信息
  260. AUDITID int64 `json:"auditid" xorm:"AUDITID"` // 审核人
  261. AUDITTIME string `json:"audittime" xorm:"AUDITTIME"` // 审核时间
  262. REMARK string `json:"remark" xorm:"REMARK"` // 备注
  263. NETADDR string `json:"netaddr" xorm:"NETADDR"` // 调转网址
  264. ACCOUNTTICKET string `json:"accountticket" xorm:"ACCOUNTTICKET"` // 最新账户服务流水号
  265. CHECKERRORFLAG int32 `json:"checkerrorflag" xorm:"CHECKERRORFLAG"` // 对账差错标志 - 1:为单边账;其它为正常出入金
  266. REMARK2 string `json:"remark2" xorm:"REMARK2"` // 备注(失败原因)
  267. REAUDITID int64 `json:"reauditid" xorm:"REAUDITID"` // 复审人
  268. REAUDITTIME string `json:"reaudittime" xorm:"REAUDITTIME"` // 复审时间
  269. REAUDITREMARK string `json:"reauditremark" xorm:"REAUDITREMARK"` // 复审备注
  270. APPLYREMARK string `json:"applyremark" xorm:"APPLYREMARK"` // 申请备注
  271. RELATEDORDERID string `json:"relatedorderid" xorm:"RELATEDORDERID"` // 三方关联ID
  272. CAPAMOUNTOUT float64 `json:"capamountout" xorm:"CAPAMOUNTOUT"` // 出金(劣后本金) - 外部子账户
  273. INFAMOUNT float64 `json:"infamount" xorm:"INFAMOUNT"` // 劣后金额(自有)
  274. PRIAMOUNT float64 `json:"priamount" xorm:"PRIAMOUNT"` // 优先金额(授信)
  275. BANK_APPLY_TICKET string `json:"bank_apply_ticket" xorm:"BANK_APPLY_TICKET"` // 银行申请流水
  276. CERTIFICATEPHOTOURL string `json:"certificatephotourl" xorm:"CERTIFICATEPHOTOURL"` // 凭证地址
  277. SOUCREAMOUNT float64 `json:"soucreamount" xorm:"SOUCREAMOUNT"` // 原始出入金金额
  278. SOUCRECURRENCYID int64 `json:"soucrecurrencyid" xorm:"SOUCRECURRENCYID"` // 原始出入金币种
  279. ACCOUNTCODE string `json:"accountcode" xorm:"ACCOUNTCODE"` // 资金账号
  280. CUSBANKID string `json:"cusbankid" xorm:"CUSBANKID"` // 托管银行编号
  281. TRADEDATE string `json:"tradedate" xorm:"TRADEDATE"` // 交易日(yyyyMMdd)
  282. EXCHTICKET string `json:"exchticket" xorm:"EXCHTICKET"` // 银行服务流水号
  283. EXTOPERATEID int64 `json:"extoperateid" xorm:"EXTOPERATEID"` // 交易服务流水号
  284. BANKTICKET string `json:"bankticket" xorm:"BANKTICKET"` // 银行流水
  285. APPLYSTATUS int32 `json:"applystatus" xorm:"APPLYSTATUS"` // 申请状态 - 1:待审核 2:待复审 3:初审拒绝 4:交易冻结中 5:交易解冻中 6:交易解冻扣款中 7:交易入金中 8:交易冻结/解冻/扣款中(银行发起出金时用) 9:银行出金中 10:银行入金中 11:成功 12:失败 13:银行审核中 14:账户服务入金失败; 15:账户服务解冻失败; 16:账户服务解冻扣款失败; 17:账户服务出金失败 18:复审通过 19:复审拒绝 20:提交审核,账户冻结中 21:审核拒绝,账户解冻中;22: 待审核,账户服务解冻回滚中; 23:待复审,账户服务解冻回滚中; 24: 审核通过,账户冻结金额检查中;25: 复审通过,账户冻结金额检查中;
  286. USERID int64 `json:"userid" xorm:"'USERID'"` // 用户id
  287. LOGINCODE string `json:"logincode" xorm:"'LOGINCODE'"` // 登录账号(账号)
  288. USERINFOTYPE int32 `json:"userinfotype" xorm:"'USERINFOTYPE'"` // 账户类型 1-个人 2-企业
  289. ACCOUNTNAME string `json:"accountname" xorm:"'ACCOUNTNAME'"` // 用户名称(名称)
  290. QUERYTYPE int32 `json:"-"` // 查询类型 1-提现 2-充值
  291. STATUS int32 `json:"-"` // 查询状态 1-待审核 2-审核通过 3-审核拒绝
  292. BeginDate string `json:"-"` // 开始日期(yyyymmdd)
  293. EndDate string `json:"-"` // 结束日期(yyyymmdd)
  294. FilterName string `json:"-"` // 账户(模糊匹配)
  295. }
  296. func (r *QhjMgrAccountOutInApply) calc() {
  297. r.BANKACCOUNTNAME = DecryptField(r.BANKACCOUNTNAME)
  298. r.BANKACCOUNTNO = DecryptField(r.BANKACCOUNTNO)
  299. }
  300. func (r *QhjMgrAccountOutInApply) buildSql() string {
  301. var sqlId utils.SQLVal = "with tmp as(select t.userid, wm_concat(t.logincode) logincode from loginaccount t group by t.userid)" +
  302. "SELECT t.EXECUTETYPE," +
  303. " t.AMOUNT," +
  304. " t.CURRENCY," +
  305. " t.CHARGE," +
  306. " t.ACCOUNTPWD," +
  307. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  308. " t.BANKID," +
  309. " t.BRANCHBANKID," +
  310. " t.BRANCHBANKNAME," +
  311. " t.BANKACCOUNTNO," +
  312. " t.BANKACCOUNTNAME," +
  313. " t.EXTENDINFO," +
  314. " t.AUDITID," +
  315. " to_char(t.AUDITTIME, 'yyyy-mm-dd hh24:mi:ss') AUDITTIME," +
  316. " t.REMARK," +
  317. " t.NETADDR," +
  318. " t.ACCOUNTTICKET," +
  319. " t.CHECKERRORFLAG," +
  320. " t.REMARK2," +
  321. " t.REAUDITID," +
  322. " to_char(t.REAUDITTIME, 'yyyy-mm-dd hh24:mi:ss') REAUDITTIME," +
  323. " t.REAUDITREMARK," +
  324. " t.APPLYREMARK," +
  325. " t.RELATEDORDERID," +
  326. " t.CAPAMOUNTOUT," +
  327. " t.INFAMOUNT," +
  328. " t.PRIAMOUNT," +
  329. " t.BANK_APPLY_TICKET," +
  330. " to_char(t.CERTIFICATEPHOTOURL) CERTIFICATEPHOTOURL," +
  331. " t.SOUCREAMOUNT," +
  332. " t.SOUCRECURRENCYID," +
  333. " t.ACCOUNTCODE," +
  334. " t.CUSBANKID," +
  335. " t.TRADEDATE," +
  336. " t.EXCHTICKET," +
  337. " t.EXTOPERATEID," +
  338. " t.BANKTICKET," +
  339. " t.APPLYSTATUS," +
  340. " ta.userid," +
  341. " u.accountname," +
  342. " ui.userinfotype," +
  343. " tmp.logincode," +
  344. " b.bankname" +
  345. " FROM BANK_ACCOUNTOUTINAPPLY t" +
  346. " INNER JOIN TAACCOUNT ta" +
  347. " on t.accountcode = to_char(ta.accountid)" +
  348. " INNER JOIN USERACCOUNT u" +
  349. " on ta.relateduserid = u.userid" +
  350. " INNER JOIN USERINFO ui" +
  351. " on u.userid = ui.userid" +
  352. " LEFT JOIN BANK_BANKINFO b on t.bankid=b.bankid" +
  353. " LEFT JOIN tmp" +
  354. " on u.userid = tmp.userid" +
  355. " WHERE 1 = 1"
  356. sqlId.And("EXECUTETYPE", r.QUERYTYPE)
  357. switch r.STATUS {
  358. case 1:
  359. sqlId.JoinFormat(" and t.APPLYSTATUS in(%v)", InStr(1, 2))
  360. case 2:
  361. sqlId.JoinFormat(" and t.APPLYSTATUS in(%v)", InStr(11, 18, 24, 25))
  362. case 3:
  363. sqlId.JoinFormat(" and t.APPLYSTATUS in(%v)", InStr(3, 12, 21))
  364. }
  365. if len(r.BeginDate) > 0 {
  366. sqlId.Join(fmt.Sprintf(" and t.TRADEDATE >= %v", r.BeginDate))
  367. }
  368. if len(r.EndDate) > 0 {
  369. sqlId.Join(fmt.Sprintf(" and t.TRADEDATE <= %v", r.EndDate))
  370. }
  371. if len(r.FilterName) > 0 {
  372. sqlId.Join(fmt.Sprintf(" and (tmp.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName))
  373. }
  374. return sqlId.String()
  375. }
  376. // GetDataEx 获取充值提现(出入金)
  377. func (r *QhjMgrAccountOutInApply) GetDataEx() (interface{}, error) {
  378. sData := make([]QhjMgrAccountOutInApply, 0)
  379. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  380. for i := range sData {
  381. sData[i].calc()
  382. }
  383. return sData, err
  384. }
  385. // QhjTradeEx 额外的用户和商品信息
  386. type QhjTradeEx struct {
  387. LOGINCODE string `json:"logincode" xorm:"'LOGINCODE'"` // 登录代码(账户)
  388. USERID int64 `json:"userid" xorm:"'USERID'"` // 用户id
  389. ACCOUNTNAME string `json:"accountname" xorm:"'ACCOUNTNAME'"` // 用户名称
  390. ENUMDICNAME string `json:"enumdicname" xorm:"'ENUMDICNAME'"` // 单位名称(商品)
  391. GOODSCODE string `json:"goodscode" xorm:"GOODSCODE"` // 商品代码(内部)
  392. GOODSNAME string `json:"goodsname" xorm:"GOODSNAME"` // 商品名称
  393. GOODUNITID int32 `json:"goodunitid" xorm:"GOODUNITID"` // 报价单位ID
  394. AGREEUNIT float64 `json:"agreeunit" xorm:"AGREEUNIT"` // 合约乘数
  395. DECIMALPLACE int32 `json:"decimalplace" xorm:"DECIMALPLACE"` // 报价小数位
  396. QTYDECIMALPLACE int32 `json:"qtydecimalplace" xorm:"QTYDECIMALPLACE"` // 成交量小数位
  397. USERINFOTYPE int32 `json:"userinfotype" xorm:"'USERINFOTYPE'"` // 账户类型 1-个人 2-企业
  398. MOBILE string `json:"-" xorm:"'MOBILE'"` // 手机号码
  399. MARKETID int32 `json:"marketid" xorm:"'MARKETID'"` // 市场id
  400. TRADEMODE int32 `json:"trademode" xorm:"'TRADEMODE'"` // 交易模式
  401. }
  402. func (r *QhjTradeEx) dealConvert() {
  403. if r.LOGINCODE == "" {
  404. r.LOGINCODE = DecryptField(r.MOBILE)
  405. }
  406. }
  407. // QhjMgrPositionRsp 持仓汇总
  408. type QhjMgrPositionRsp struct {
  409. QhjTradeEx `xorm:"extends"`
  410. ACCOUNTID int64 `json:"accountid"` // 账号Id
  411. GOODSID int32 `json:"goodsid"` // 商品Id
  412. HOLDERTYPE int32 `json:"holdertype"` // 持仓类别 - 1:单边持仓 2:双边持仓
  413. HOLDERQTY float64 `json:"holderqty"` // 持有数量
  414. FROZENQTY float64 `json:"frozenqty"` // 冻结数量
  415. AVIALQTY float64 `json:"avialqty"` // 可用数量
  416. HOLDERAMOUNT float64 `json:"holderamount"` // 金额
  417. AVERAGEPRICE float64 `json:"averageprice"` // 均价
  418. }
  419. // QhjMgrTradePosition 持仓汇总
  420. type QhjMgrTradePosition struct {
  421. ACCOUNTID int64 `json:"accountid" xorm:"ACCOUNTID"` // 账号Id
  422. GOODSID int32 `json:"goodsid" xorm:"GOODSID"` // 商品Id
  423. HOLDERTYPE int32 `json:"holdertype" xorm:"HOLDERTYPE"` // 持仓类别 - 1:单边持仓 2:双边持仓
  424. BUYPOSITIONQTY float64 `json:"buypositionqty" xorm:"BUYPOSITIONQTY"` // 买期初持仓数量
  425. BUYHOLDERAMOUNT float64 `json:"buyholderamount" xorm:"BUYHOLDERAMOUNT"` // 买期初持仓总金额[商品币种]
  426. BUYCURPOSITIONQTY float64 `json:"buycurpositionqty" xorm:"BUYCURPOSITIONQTY"` // 买当前持仓总数量
  427. BUYCURHOLDERAMOUNT float64 `json:"buycurholderamount" xorm:"BUYCURHOLDERAMOUNT"` // 买当前持仓总金额[商品币种]
  428. BUYFROZENQTY float64 `json:"buyfrozenqty" xorm:"BUYFROZENQTY"` // 买持仓冻结数量
  429. BUYOTHERFROZENQTY float64 `json:"buyotherfrozenqty" xorm:"BUYOTHERFROZENQTY"` // 买持仓其他冻结数量(交割冻结)
  430. BUYOPENREQQTY float64 `json:"buyopenreqqty" xorm:"BUYOPENREQQTY"` // 买开仓申请数量(用于比较最大持仓数量)
  431. BUYOPENTOTALQTY float64 `json:"buyopentotalqty" xorm:"BUYOPENTOTALQTY"` // 今日买开仓总数量
  432. BUYCLOSETOTALQTY float64 `json:"buyclosetotalqty" xorm:"BUYCLOSETOTALQTY"` // 今日买平仓总数量
  433. SELLPOSITIONQTY float64 `json:"sellpositionqty" xorm:"SELLPOSITIONQTY"` // 卖期初持仓数量
  434. SELLHOLDERAMOUNT float64 `json:"sellholderamount" xorm:"SELLHOLDERAMOUNT"` // 卖期初持仓总金额[商品币种]
  435. SELLCURPOSITIONQTY float64 `json:"sellcurpositionqty" xorm:"SELLCURPOSITIONQTY"` // 卖当前持仓数量
  436. SELLCURHOLDERAMOUNT float64 `json:"sellcurholderamount" xorm:"SELLCURHOLDERAMOUNT"` // 卖当前持仓总金额[商品币种]
  437. SELLFROZENQTY float64 `json:"sellfrozenqty" xorm:"SELLFROZENQTY"` // 卖持仓冻结
  438. SELLOTHERFROZENQTY float64 `json:"sellotherfrozenqty" xorm:"SELLOTHERFROZENQTY"` // 卖持仓其他冻结(交割冻结)
  439. SELLOPENREQQTY float64 `json:"sellopenreqqty" xorm:"SELLOPENREQQTY"` // 卖开仓申请数量(用于比较最大持仓数量)
  440. SELLOPENTOTALQTY float64 `json:"sellopentotalqty" xorm:"SELLOPENTOTALQTY"` // 今日卖开仓总数量
  441. SELLCLOSETOTALQTY float64 `json:"sellclosetotalqty" xorm:"SELLCLOSETOTALQTY"` // 今日卖平仓总数量
  442. USEDMARGIN float64 `json:"usedmargin" xorm:"USEDMARGIN"` // 占用保证金[商品币种]
  443. TRADEPROPERTY int32 `json:"tradeproperty" xorm:"TRADEPROPERTY"` // 交易属性
  444. BUYTNQTY float64 `json:"buytnqty" xorm:"BUYTNQTY"` // 买T+N冻结总量
  445. BUYTNUSEDQTY float64 `json:"buytnusedqty" xorm:"BUYTNUSEDQTY"` // 买T+N使用量(可以使用T+N的冻结数量)
  446. SELLTNQTY float64 `json:"selltnqty" xorm:"SELLTNQTY"` // 卖T+N冻结总量
  447. SELLTNUSEDQTY float64 `json:"selltnusedqty" xorm:"SELLTNUSEDQTY"` // 卖T+N使用量(可以使用T+N的冻结数量)
  448. BUYCURTDPOSITION float64 `json:"buycurtdposition" xorm:"BUYCURTDPOSITION"` // 买期末今日头寸
  449. BUYFRETDPOSITION float64 `json:"buyfretdposition" xorm:"BUYFRETDPOSITION"` // 买冻结今日头寸
  450. SELLCURTDPOSITION float64 `json:"sellcurtdposition" xorm:"SELLCURTDPOSITION"` // 卖期末今日头寸
  451. SELLFRETDPOSITION float64 `json:"sellfretdposition" xorm:"SELLFRETDPOSITION"` // 卖冻结今日头寸
  452. QhjTradeEx `xorm:"extends"`
  453. IncludeSub int32 `json:"-"` // 是否包含子级 1-包含
  454. FilterName string `json:"-"` // 模糊搜索
  455. }
  456. func (r *QhjMgrTradePosition) calc() {
  457. r.dealConvert()
  458. }
  459. func (r *QhjMgrTradePosition) buildSql() string {
  460. var sqlId utils.SQLVal = "with k as" +
  461. " (select t.userid, wm_concat(t.logincode) logincode" +
  462. " from loginaccount t" +
  463. " group by t.userid)" +
  464. "select u.userid," +
  465. " u.accountname," +
  466. " k.logincode," +
  467. " u.subarealevelpath," +
  468. " ui.userinfotype," +
  469. " ui.mobile," +
  470. " g.goodsname," +
  471. " g.goodscode," +
  472. " g.goodunitid," +
  473. " g.qtydecimalplace," +
  474. " g.decimalplace," +
  475. " g.agreeunit," +
  476. " m.marketid," +
  477. " m.trademode," +
  478. " e.enumdicname," +
  479. " t.*" +
  480. " from tradeposition t" +
  481. " inner join taaccount ta" +
  482. " on t.accountid = ta.accountid" +
  483. " inner join useraccount u" +
  484. " on ta.relateduserid = u.userid" +
  485. " inner join userinfo ui" +
  486. " on u.userid = ui.userid" +
  487. " left join k" +
  488. " on u.userid = k.userid" +
  489. " left join goods g" +
  490. " on t.goodsid = g.goodsid" +
  491. " left join market m on g.marketid=m.marketid" +
  492. " left join enumdicitem e" +
  493. " on e.enumitemname = g.goodunitid" +
  494. " and e.enumdiccode = 'goodsunit'" +
  495. " where 1 = 1"
  496. if r.IncludeSub == 1 {
  497. sqlId.JoinFormat(" and u.subarealevelpath like '%%,%v,%%'", r.USERID)
  498. } else {
  499. sqlId.And("u.parentuserid", r.USERID)
  500. }
  501. sqlId.AndEx("ui.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  502. sqlId.AndEx("m.TRADEMODE", r.TRADEMODE, r.TRADEMODE > 0)
  503. sqlId.AndEx("t.goodsid", r.GOODSID, r.GOODSID > 0)
  504. if len(r.FilterName) > 0 {
  505. sqlId.JoinFormat(" and (k.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName)
  506. }
  507. return sqlId.String()
  508. }
  509. // GetDataEx 获取持仓汇总
  510. func (r *QhjMgrTradePosition) GetDataEx() (interface{}, error) {
  511. sData := make([]QhjMgrTradePosition, 0)
  512. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  513. sData2 := make([]QhjMgrPositionRsp, 0)
  514. for i := range sData {
  515. sData[i].calc()
  516. v := QhjMgrPositionRsp{QhjTradeEx: sData[i].QhjTradeEx}
  517. v.GOODSID = sData[i].GOODSID
  518. v.ACCOUNTID, v.HOLDERTYPE = sData[i].ACCOUNTID, sData[i].HOLDERTYPE
  519. v.HOLDERAMOUNT = sData[i].BUYCURHOLDERAMOUNT
  520. v.HOLDERQTY = sData[i].BUYCURPOSITIONQTY
  521. v.FROZENQTY = sData[i].BUYFROZENQTY
  522. v.AVIALQTY = v.HOLDERQTY - v.FROZENQTY
  523. zoomFun := NewZoomFun(int(v.QTYDECIMALPLACE))
  524. zoomFun(&v.HOLDERQTY, &v.FROZENQTY, &v.AVIALQTY)
  525. if v.HOLDERQTY > 1e-10 {
  526. v.AVERAGEPRICE = v.HOLDERAMOUNT / v.HOLDERQTY
  527. }
  528. sData2 = append(sData2, v)
  529. }
  530. return sData2, err
  531. }
  532. // QhjMgrTradeDetailRsp
  533. type QhjMgrTradeDetailRsp struct {
  534. TRADEID string `json:"tradeid"` // 成交单号
  535. GOODSID int32 `json:"goodsid"` // 商品id
  536. BUYORSELL int32 `json:"buyorsell"` // 成交类型(方向) 0:买 1:卖
  537. ORDERID string `json:"orderid"` // 关联委托单号
  538. TRADEDATE string `json:"tradedate"` // 交易日
  539. ACCOUNTID int64 `json:"accountid"` // 资金账号
  540. TRADETIME string `json:"tradetime"` // 成交时间
  541. TRADEPRICE float64 `json:"tradeprice"` // 价格
  542. TRADEQTY float64 `json:"tradeqty"` // 数量
  543. TRADEAMOUNT float64 `json:"tradeamount"` // 金额
  544. QhjTradeEx `xorm:"extends"`
  545. }
  546. // QhjMgrTradeDetail 成交明细
  547. type QhjMgrTradeDetail struct {
  548. TRADEID string `json:"tradeid" xorm:"TRADEID2"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  549. BUYORSELL int32 `json:"buyorsell" xorm:"BUYORSELL"` // 方向 - 0:买 1:卖
  550. ORDERID string `json:"orderid" xorm:"ORDERID2"` // 委托单号
  551. TRADEDATE string `json:"tradedate" xorm:"TRADEDATE"` // 交易日(yyyyMMdd)
  552. ACCOUNTID int64 `json:"accountid" xorm:"ACCOUNTID"` // 账户ID[报价币种]
  553. GOODSID int32 `json:"goodsid" xorm:"GOODSID"` // 商品ID
  554. MEMBERUSERID int64 `json:"memberuserid" xorm:"MEMBERUSERID"` // 会员id 个人投资者 需要填写
  555. MATCHACCOUNTID int64 `json:"matchaccountid" xorm:"MATCHACCOUNTID"` // 对手账号id
  556. TRADETIME string `json:"tradetime" xorm:"TRADETIME2"` // 成交时间
  557. TRADEPRICE float64 `json:"tradeprice" xorm:"TRADEPRICE"` // 成交价格
  558. TRADEQTY float64 `json:"tradeqty" xorm:"TRADEQTY"` // 成交数量
  559. TRADEAMOUNT float64 `json:"tradeamount" xorm:"TRADEAMOUNT"` // 成交金额[账户币种,用于所有权]
  560. CLOSEPL float64 `json:"closepl" xorm:"CLOSEPL"` // 平仓盈亏
  561. INTCLOSEPL int64 `json:"intclosepl" xorm:"INTCLOSEPL"` // 整型盈亏(用于交易结算试算平衡-收益权)
  562. OPENCHARGE float64 `json:"opencharge" xorm:"OPENCHARGE"` // 建仓手续费(支付总手续费=(交易所比率+会员比率)*成交金额)
  563. CLOSECHARGE float64 `json:"closecharge" xorm:"CLOSECHARGE"` // 平仓手续费(支付总手续费=(交易所比率+会员比率)*成交金额)
  564. TRADETYPE int32 `json:"tradetype" xorm:"TRADETYPE"` // 成交类别 - 1:正常委托成交 2:定向做市成交(接单) 3:交割协议平仓成交 4:交割减仓成交 5:到期强平成交 6:风控斩仓成交 7:协议平仓(管理端)成交 8:仓单转持仓成交 9: 交割协议转让成交 10:受托竞价成交(接单) 11:协议转让成交 12:系统强行平仓 13:期权违约平仓
  565. BUILDTYPE int32 `json:"buildtype" xorm:"BUILDTYPE"` // 委托单据类型 1:建仓 2:平仓 3:先平后建
  566. OPENQTY float64 `json:"openqty" xorm:"OPENQTY"` // 开仓数量(先建后平操作 需要记录)
  567. CLOSEQTY float64 `json:"closeqty" xorm:"CLOSEQTY"` // 平仓数量(先建后平操作 需要记录)
  568. STATUS int32 `json:"status" xorm:"STATUS"` // 处理状态 - 1:待处理 2:已处理 3:处理失败
  569. ISRECKONED int32 `json:"isreckoned" xorm:"ISRECKONED"` // 是否结算 - 0:未结算 1:已结算
  570. TRADEPROPERTY int32 `json:"tradeproperty" xorm:"TRADEPROPERTY"` // 交易属性
  571. OPENFEEALGORITHM int32 `json:"openfeealgorithm" xorm:"OPENFEEALGORITHM"` // 建仓手续费收取方式 1:比率 2:固定
  572. OPENMEMBERCHARGEVALUE float64 `json:"openmemberchargevalue" xorm:"OPENMEMBERCHARGEVALUE"` // 建仓会员手续费设置值
  573. OPENEXCHAGECHARGEVALUE float64 `json:"openexchagechargevalue" xorm:"OPENEXCHAGECHARGEVALUE"` // 建仓交易所手续费设置值
  574. CLOSEFEEALGORITHM int32 `json:"closefeealgorithm" xorm:"CLOSEFEEALGORITHM"` // 平仓手续费收取方式 1:比率 2:固定
  575. CLOSEMEMBERCHARGEVALUE float64 `json:"closememberchargevalue" xorm:"CLOSEMEMBERCHARGEVALUE"` // 平仓会员手续费设置值
  576. CLOSEEXCHAGECHARGEVALUE float64 `json:"closeexchagechargevalue" xorm:"CLOSEEXCHAGECHARGEVALUE"` // 平仓交易所手续费设置值
  577. OPTIONTYPE int32 `json:"optiontype" xorm:"OPTIONTYPE"` // 期权类型 - 1:认购(看涨) 2:认沽(看跌)
  578. PREMIUM float64 `json:"premium" xorm:"PREMIUM"` // 权利金 - [持仓单的权利金]
  579. ISPREEXERCISE int32 `json:"ispreexercise" xorm:"ISPREEXERCISE"` // 是否预申报- 0:否 1:是
  580. PREEXERCISEPRICE float64 `json:"preexerciseprice" xorm:"PREEXERCISEPRICE"` // 预申报价格
  581. ISCONFIRMEXERCISE int32 `json:"isconfirmexercise" xorm:"ISCONFIRMEXERCISE"` // 是否确认行权- 0:否 1:是
  582. ISMAIN int32 `json:"ismain" xorm:"ISMAIN"` // 是否主单 - 0:不是 1:是
  583. PERFORMANCEPLANID int64 `json:"performanceplanid" xorm:"PERFORMANCEPLANID"` // 履约计划ID[期权]
  584. PERFORMANCESTATUS int32 `json:"performancestatus" xorm:"PERFORMANCESTATUS"` // 履约状态[期权] - 0:无履约 1:未履约 2:履约中 3:履约完成
  585. CREDITAMOUNT float64 `json:"creditamount" xorm:"CREDITAMOUNT"` // 授信金额
  586. GCACCOUNTID int64 `json:"gcaccountid" xorm:"GCACCOUNTID"` // 账户ID[合约币种]
  587. CLOSEPL2 float64 `json:"closepl2" xorm:"CLOSEPL2"` // 平仓盈亏[逐笔]
  588. RELATEDOUTTRADEID int64 `json:"relatedouttradeid" xorm:"RELATEDOUTTRADEID"` // 关联外部成交单ID
  589. QhjTradeEx `xorm:"extends"`
  590. IncludeSub int32 `json:"-"` // 是否包含子级 1-包含
  591. BeginDate string `json:"-"` // 开始交易日
  592. EndDate string `json:"-"` // 结束交易日
  593. FilterName string `json:"-"` // 模糊搜索
  594. }
  595. func (r *QhjMgrTradeDetail) calc() {
  596. r.dealConvert()
  597. }
  598. func (r *QhjMgrTradeDetail) buildSql(bQueryHis bool) string {
  599. var sqlId utils.SQLVal = "with k as" +
  600. " (select t.userid, wm_concat(t.logincode) logincode" +
  601. " from loginaccount t" +
  602. " group by t.userid)" +
  603. "select u.userid," +
  604. " u.accountname," +
  605. " k.logincode," +
  606. " u.subarealevelpath," +
  607. " ui.userinfotype," +
  608. " ui.mobile," +
  609. " g.goodsname," +
  610. " g.goodscode," +
  611. " g.goodunitid," +
  612. " g.qtydecimalplace," +
  613. " g.decimalplace," +
  614. " g.agreeunit," +
  615. " m.marketid," +
  616. " m.trademode," +
  617. " e.enumdicname," +
  618. " to_char(t.TRADEID) TRADEID2," +
  619. " to_char(t.ORDERID) ORDERID2," +
  620. " to_char(t.TRADETIME, 'yyyy-mm-dd hh24:mi:ss') TRADETIME2," +
  621. " t.*" +
  622. " from %v t" +
  623. " inner join taaccount ta" +
  624. " on t.accountid = ta.accountid" +
  625. " inner join useraccount u" +
  626. " on ta.relateduserid = u.userid" +
  627. " inner join userinfo ui" +
  628. " on u.userid = ui.userid" +
  629. " left join k" +
  630. " on u.userid = k.userid" +
  631. " left join goods g" +
  632. " on t.goodsid = g.goodsid" +
  633. " left join market m on g.marketid=m.marketid" +
  634. " left join enumdicitem e" +
  635. " on e.enumitemname = g.goodunitid" +
  636. " and e.enumdiccode = 'goodsunit'" +
  637. " where 1 = 1"
  638. if bQueryHis {
  639. sqlId.FormatParam("his_trade_tradedetail")
  640. sqlId.And("t.isvaliddata", 1)
  641. } else {
  642. sqlId.FormatParam("trade_tradedetail")
  643. }
  644. if r.IncludeSub == 1 {
  645. sqlId.JoinFormat(" and u.subarealevelpath like '%%,%v,%%'", r.USERID)
  646. } else {
  647. sqlId.And("u.parentuserid", r.USERID)
  648. }
  649. sqlId.AndEx("ui.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  650. sqlId.AndEx("m.TRADEMODE", r.TRADEMODE, r.TRADEMODE > 0)
  651. sqlId.AndEx("t.goodsid", r.GOODSID, r.GOODSID > 0)
  652. if len(r.BeginDate) > 0 {
  653. sqlId.JoinFormat(" and t.TRADEDATE >=%v", r.BeginDate)
  654. }
  655. if len(r.EndDate) > 0 {
  656. sqlId.JoinFormat(" and t.TRADEDATE <=%v", r.EndDate)
  657. }
  658. if len(r.FilterName) > 0 {
  659. sqlId.JoinFormat(" and (k.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName)
  660. }
  661. return sqlId.String()
  662. }
  663. // GetDataEx 获取成交明细
  664. func (r *QhjMgrTradeDetail) GetDataEx() (interface{}, error) {
  665. sData := make([]QhjMgrTradeDetail, 0)
  666. sCurData := make([]QhjMgrTradeDetail, 0)
  667. err := db.GetEngine().SQL(r.buildSql(false)).Find(&sCurData)
  668. sHisData := make([]QhjMgrTradeDetail, 0)
  669. err = db.GetEngine().SQL(r.buildSql(true)).Find(&sHisData)
  670. sData2 := make([]QhjMgrTradeDetailRsp, 0)
  671. sData = append(sData, sCurData...)
  672. sData = append(sData, sHisData...)
  673. for i := range sData {
  674. sData[i].calc()
  675. v := QhjMgrTradeDetailRsp{QhjTradeEx: sData[i].QhjTradeEx}
  676. v.ACCOUNTID, v.TRADEID = sData[i].ACCOUNTID, sData[i].TRADEID
  677. v.TRADEAMOUNT, v.TRADEQTY = sData[i].TRADEAMOUNT, sData[i].TRADEQTY
  678. v.TRADEDATE, v.TRADETIME = sData[i].TRADEDATE, sData[i].TRADETIME
  679. v.GOODSID, v.ORDERID = sData[i].GOODSID, sData[i].ORDERID
  680. zoonFun := NewZoomFun(int(v.QTYDECIMALPLACE))
  681. zoonFun(&v.TRADEQTY)
  682. sData2 = append(sData2, v)
  683. }
  684. return sData2, err
  685. }
  686. // QhjMgrTradeOrderDetailRsp 委托明细(给终端)
  687. type QhjMgrTradeOrderDetailRsp struct {
  688. GOODSID int32 `json:"goodsid"` // 商品id
  689. ORDERID string `json:"orderid"` // 关联委托单号
  690. TRADEDATE string `json:"tradedate"` // 交易日
  691. ACCOUNTID int64 `json:"accountid"` // 资金账号
  692. ORDERTIME string `json:"ordertime"` // 委托时间
  693. ORDERPRICE float64 `json:"orderprice"` // 价格
  694. ORDERQTY float64 `json:"orderqty"` // 数量
  695. AMOUNT float64 `json:"amount"` // 金额
  696. ORDERSTATUS int32 `json:"orderstatus"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
  697. QhjTradeEx `xorm:"extends"`
  698. }
  699. // QhjMgrTradeOrderDetail 委托明细
  700. type QhjMgrTradeOrderDetail struct {
  701. CLOSEMEMBERCHARGEVALUE float64 `json:"closememberchargevalue" xorm:"CLOSEMEMBERCHARGEVALUE"` // 平仓会员手续费设置值
  702. CLOSEEXCHAGECHARGEVALUE float64 `json:"closeexchagechargevalue" xorm:"CLOSEEXCHAGECHARGEVALUE"` // 平仓交易所手续费设置值
  703. OPTIONTYPE int32 `json:"optiontype" xorm:"OPTIONTYPE"` // 期权类型 - 1:认购(看涨) 2:认沽(看跌)
  704. PREMIUM float64 `json:"premium" xorm:"PREMIUM"` // 权利金
  705. ISPREEXERCISE int32 `json:"ispreexercise" xorm:"ISPREEXERCISE"` // 是否预申报- 0:否 1:是
  706. PREEXERCISEPRICE float64 `json:"preexerciseprice" xorm:"PREEXERCISEPRICE"` // 预申报价格
  707. ISCONFIRMEXERCISE int32 `json:"isconfirmexercise" xorm:"ISCONFIRMEXERCISE"` // 是否确认行权- 0:否 1:是
  708. QUOTEID int64 `json:"quoteid" xorm:"QUOTEID"` // 报价单ID
  709. GCACCOUNTID int64 `json:"gcaccountid" xorm:"GCACCOUNTID"` // 账户ID[合约币种]
  710. SESSIONID int64 `json:"sessionid" xorm:"SESSIONID"` // 会话ID
  711. FREEZEQTY float64 `json:"freezeqty" xorm:"FREEZEQTY"` // 冻结数量
  712. AMOUNTFLAG int32 `json:"amountflag" xorm:"AMOUNTFLAG"` // 资金标识 - 1:余额 2;待付
  713. ORDERFLAG int32 `json:"orderflag" xorm:"ORDERFLAG"` // 委托标识 - 1:按量 2:按金额
  714. ORDERID string `json:"orderid" xorm:"ORDERID2"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  715. TRADEDATE string `json:"tradedate" xorm:"TRADEDATE"` // 交易日(yyyyMMdd)
  716. BUILDTYPE int32 `json:"buildtype" xorm:"BUILDTYPE"` // 委托单据类型 - 1:建仓 2:平仓 3:先平后建
  717. PREORDERID string `json:"preorderid" xorm:"PREORDERID"` // 关联预埋单号(止盈止损单时填写)
  718. CANCELORDERID int64 `json:"cancelorderid" xorm:"CANCELORDERID"` // 撤单单号(撤单时填写)
  719. RELATEDID string `json:"relatedid" xorm:"RELATEDID"` // 关联单号(交割单)
  720. MARKETID int32 `json:"marketid" xorm:"MARKETID"` // 市场ID
  721. GOODSID int32 `json:"goodsid" xorm:"GOODSID"` // 商品ID
  722. ACCOUNTID int64 `json:"accountid" xorm:"ACCOUNTID"` // 账户ID[报价币种]
  723. MEMBERUSERID int64 `json:"memberuserid" xorm:"MEMBERUSERID"` // 所属会员UserID
  724. BUYORSELL int32 `json:"buyorsell" xorm:"BUYORSELL"` // 买卖 - 0:买 1:卖
  725. PRICEMODE int32 `json:"pricemode" xorm:"PRICEMODE"` // 取价方式 - 1:市价 2: 限价
  726. ORDERPRICE float64 `json:"orderprice" xorm:"ORDERPRICE"` // 委托价格
  727. MARKETMAXSUB float64 `json:"marketmaxsub" xorm:"MARKETMAXSUB"` // 市价最大偏移范围
  728. ORDERQTY float64 `json:"orderqty" xorm:"ORDERQTY"` // 委托数量
  729. TRADEQTY float64 `json:"tradeqty" xorm:"TRADEQTY"` // 成交数量
  730. CANCELQTY float64 `json:"cancelqty" xorm:"CANCELQTY"` // 撤单数量
  731. OPENQTY float64 `json:"openqty" xorm:"OPENQTY"` // 开仓数量(先建后平操作,需要记录)
  732. CLOSEQTY float64 `json:"closeqty" xorm:"CLOSEQTY"` // 平仓数量(先建后平操作 需要记录)
  733. OPENTRADEQTY float64 `json:"opentradeqty" xorm:"OPENTRADEQTY"` // 开仓成交数量(先建后平操作,需要记录)
  734. CLOSETRADEQTY float64 `json:"closetradeqty" xorm:"CLOSETRADEQTY"` // 平仓成交数量(先建后平操作,需要记录)
  735. FREEZEMARGIN float64 `json:"freezemargin" xorm:"FREEZEMARGIN"` // 冻结保证金(冻结交易金额)
  736. UNFREEZEMARGIN float64 `json:"unfreezemargin" xorm:"UNFREEZEMARGIN"` // 解冻保证金
  737. FREEZECHARGE float64 `json:"freezecharge" xorm:"FREEZECHARGE"` // 冻结手续费
  738. UNFREEZECHARGE float64 `json:"unfreezecharge" xorm:"UNFREEZECHARGE"` // 解冻手续费
  739. OPENFREEZECHARGE float64 `json:"openfreezecharge" xorm:"OPENFREEZECHARGE"` // 开仓冻结手续费(先建后平操作,需要记录)
  740. CLOSEFREEZECHARGE float64 `json:"closefreezecharge" xorm:"CLOSEFREEZECHARGE"` // 平仓冻结手续费(先建后平操作,需要记录)
  741. OPENUNFREEZECHARGE float64 `json:"openunfreezecharge" xorm:"OPENUNFREEZECHARGE"` // 开仓解冻手续费(先建后平操作,需要记录)
  742. CLOSEUNFREEZECHARGE float64 `json:"closeunfreezecharge" xorm:"CLOSEUNFREEZECHARGE"` // 平仓解冻手续费(先建后平操作,需要记录)
  743. VALIDTYPE int32 `json:"validtype" xorm:"VALIDTYPE"` // 有效类型 - 1当日有效 2本周有效 3指定日期有效 4一直有效 5指定时间有效
  744. VALIDTIME string `json:"validtime" xorm:"VALIDTIME"` // 有效期限
  745. VOLUMETYPE int32 `json:"volumetype" xorm:"VOLUMETYPE"` // 当时间有效类型为 “立即执行否则取消 IOC” 时,需要此项 - 0:任意量 1:最小量(暂时不支持) 2:全部量
  746. OPERATETYPE int32 `json:"operatetype" xorm:"OPERATETYPE"` // 操作类型 - 1:正常下单 2:斩仓 3:转单 4:结算撤单 5:系统卖出(适用于先平后建的卖出) 6:行情源报价 7:(结算)到期强平 8:(结算)协议转让 9:系统对冲单 10:(结算)到期无效 11:交割协议转让 12:交割协议平仓 13:交割成交(所有权) 14:管理端强行平仓 15:管理端协议转让 ... 23:融资买入
  747. ORDERTIME string `json:"ordertime" xorm:"ORDERTIME2"` // 委托时间
  748. ORDERSRC int32 `json:"ordersrc" xorm:"ORDERSRC"` // 委托来源 - 1:客户端 2:管理端 3:风控服务 4:交割服务 5:交易服务 6:交易日结 7:商品强平 8:管理端商品退市强平 9:交易接口 10:交割服务商被动(受托竞价) 11:预埋触发
  749. ORDERSTATUS int32 `json:"orderstatus" xorm:"ORDERSTATUS"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
  750. OPERATORID int64 `json:"operatorid" xorm:"OPERATORID"` // 登录账号(LoginID)
  751. UPDATETIME string `json:"updatetime" xorm:"UPDATETIME"` // 更新时间
  752. CLIENTORDERTIME string `json:"clientordertime" xorm:"CLIENTORDERTIME"` // 客户端委托时间
  753. CLIENTTICKET string `json:"clientticket" xorm:"CLIENTTICKET"` // 客户端流水号
  754. UUID string `json:"uuid" xorm:"UUID"` // 发起端唯一id
  755. CLIENTTYPE int32 `json:"clienttype" xorm:"CLIENTTYPE"` // 客户端类型 - 0:保留为未填终端类型 1:PC管理端 2:PC交易端 3:手机客户端_安卓 4:网页客户端 5:微信客户端 6:手机客户端_苹果 7:网上开户客户端 8:无效终端编号 9:报价终端(中江)
  756. RETCODE int32 `json:"retcode" xorm:"RETCODE"` // 错误代码
  757. TRADEPROPERTY int32 `json:"tradeproperty" xorm:"TRADEPROPERTY"` // 交易属性
  758. LISTINGSELECTTYPE int32 `json:"listingselecttype" xorm:"LISTINGSELECTTYPE"` // 挂牌点选类型 - 1:挂牌 2:摘牌 3:先摘后挂
  759. DELISTINGTYPE int32 `json:"delistingtype" xorm:"DELISTINGTYPE"` // 摘牌类型 - 1:价格最优 2:点选成交
  760. MARGINALGORITHM int32 `json:"marginalgorithm" xorm:"MARGINALGORITHM"` // 保证金收取方式 1:比率 2:固定
  761. MARGINVALUE float64 `json:"marginvalue" xorm:"MARGINVALUE"` // 即市保证金设置值
  762. OPENFEEALGORITHM int32 `json:"openfeealgorithm" xorm:"OPENFEEALGORITHM"` // 建仓手续费收取方式 1:比率 2:固定
  763. OPENMEMBERCHARGEVALUE float64 `json:"openmemberchargevalue" xorm:"OPENMEMBERCHARGEVALUE"` // 建仓会员手续费设置值
  764. OPENEXCHAGECHARGEVALUE float64 `json:"openexchagechargevalue" xorm:"OPENEXCHAGECHARGEVALUE"` // 建仓交易所手续费设置值
  765. CLOSEFEEALGORITHM int32 `json:"closefeealgorithm" xorm:"CLOSEFEEALGORITHM"` // 平仓手续费收取方式 1:比率 2:固定
  766. QhjTradeEx `xorm:"extends"`
  767. IncludeSub int32 `json:"-"` // 是否包含子级 1-包含
  768. BeginDate string `json:"-"` // 开始交易日
  769. EndDate string `json:"-"` // 结束交易日
  770. FilterName string `json:"-"` // 模糊搜索
  771. }
  772. func (r *QhjMgrTradeOrderDetail) calc() {
  773. r.dealConvert()
  774. }
  775. func (r *QhjMgrTradeOrderDetail) buildSql(bQueryHis bool) string {
  776. var sqlId utils.SQLVal = "with k as" +
  777. " (select t.userid, wm_concat(t.logincode) logincode" +
  778. " from loginaccount t" +
  779. " group by t.userid)" +
  780. "select u.userid," +
  781. " u.accountname," +
  782. " k.logincode," +
  783. " u.subarealevelpath," +
  784. " ui.userinfotype," +
  785. " ui.mobile," +
  786. " g.goodsname," +
  787. " g.goodscode," +
  788. " g.goodunitid," +
  789. " g.qtydecimalplace," +
  790. " g.decimalplace," +
  791. " g.agreeunit," +
  792. " m.marketid," +
  793. " m.trademode," +
  794. " e.enumdicname," +
  795. " to_char(t.ORDERID) ORDERID2," +
  796. " to_char(t.ordertime, 'yyyy-mm-dd hh24:mi:ss') ORDERTIME2," +
  797. " t.*" +
  798. " from %v t" +
  799. " inner join taaccount ta" +
  800. " on t.accountid = ta.accountid" +
  801. " inner join useraccount u" +
  802. " on ta.relateduserid = u.userid" +
  803. " inner join userinfo ui" +
  804. " on u.userid = ui.userid" +
  805. " left join k" +
  806. " on u.userid = k.userid" +
  807. " left join goods g" +
  808. " on t.goodsid = g.goodsid" +
  809. " left join market m" +
  810. " on g.marketid = m.marketid" +
  811. " left join enumdicitem e" +
  812. " on e.enumitemname = g.goodunitid" +
  813. " and e.enumdiccode = 'goodsunit'" +
  814. " where 1 = 1"
  815. if bQueryHis {
  816. sqlId.FormatParam("his_trade_orderdetail")
  817. sqlId.And("t.isvaliddata", 1)
  818. } else {
  819. sqlId.FormatParam("trade_orderdetail")
  820. }
  821. if r.IncludeSub == 1 {
  822. sqlId.JoinFormat(" and u.subarealevelpath like '%%,%v,%%'", r.USERID)
  823. } else {
  824. sqlId.And("u.parentuserid", r.USERID)
  825. }
  826. sqlId.AndEx("ui.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  827. sqlId.AndEx("m.TRADEMODE", r.TRADEMODE, r.TRADEMODE > 0)
  828. sqlId.AndEx("t.goodsid", r.GOODSID, r.GOODSID > 0)
  829. if len(r.BeginDate) > 0 {
  830. sqlId.JoinFormat(" and t.TRADEDATE >=%v", r.BeginDate)
  831. }
  832. if len(r.EndDate) > 0 {
  833. sqlId.JoinFormat(" and t.TRADEDATE <=%v", r.EndDate)
  834. }
  835. if len(r.FilterName) > 0 {
  836. sqlId.JoinFormat(" and (k.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName)
  837. }
  838. return sqlId.String()
  839. }
  840. // GetDataEx 获取委托明细
  841. func (r *QhjMgrTradeOrderDetail) GetDataEx() (interface{}, error) {
  842. sData := make([]QhjMgrTradeOrderDetail, 0)
  843. sCurData := make([]QhjMgrTradeOrderDetail, 0)
  844. err := db.GetEngine().SQL(r.buildSql(false)).Find(&sCurData)
  845. sHisData := make([]QhjMgrTradeOrderDetail, 0)
  846. err = db.GetEngine().SQL(r.buildSql(true)).Find(&sHisData)
  847. sData2 := make([]QhjMgrTradeOrderDetailRsp, 0)
  848. sData = append(sData, sCurData...)
  849. sData = append(sData, sHisData...)
  850. for i := range sData {
  851. sData[i].calc()
  852. v := QhjMgrTradeOrderDetailRsp{QhjTradeEx: sData[i].QhjTradeEx}
  853. v.ACCOUNTID, v.ORDERID = sData[i].ACCOUNTID, sData[i].ORDERID
  854. v.ORDERPRICE, v.ORDERQTY = sData[i].ORDERPRICE, sData[i].ORDERQTY
  855. v.TRADEDATE, v.ORDERTIME = sData[i].TRADEDATE, sData[i].ORDERTIME
  856. v.GOODSID, v.ORDERSTATUS = sData[i].GOODSID, sData[i].ORDERSTATUS
  857. zoonFun := NewZoomFun(int(v.QTYDECIMALPLACE))
  858. zoonFun(&v.ORDERQTY)
  859. v.AMOUNT = v.ORDERPRICE * v.ORDERQTY * v.AGREEUNIT
  860. sData2 = append(sData2, v)
  861. }
  862. return sData2, err
  863. }
  864. // QhjMgrTradePayOrder 待付款单据
  865. type QhjMgrTradePayOrder struct {
  866. TRADEID string `json:"tradeid" xorm:"TRADEID"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
  867. TRADEDATE string `json:"tradedate" xorm:"TRADEDATE"` // 交易日(yyyyMMdd)
  868. MARKETID int32 `json:"marketid" xorm:"MARKETID"` // 市场ID
  869. GOODSID int32 `json:"goodsid" xorm:"GOODSID"` // 商品ID
  870. BUYORDERID string `json:"buyorderid" xorm:"BUYORDERID"` // 买方委托单号(关联单号)
  871. BUYACCOUNTID int64 `json:"buyaccountid" xorm:"BUYACCOUNTID"` // 买方账号ID[报价币种]
  872. SELLORDERID string `json:"sellorderid" xorm:"SELLORDERID"` // 卖方委托单号
  873. SELLACCOUNTID int64 `json:"sellaccountid" xorm:"SELLACCOUNTID"` // 卖方账号ID[报价币种]
  874. TRADEAMOUNT float64 `json:"tradeamount" xorm:"TRADEAMOUNT"` // 成交金额(优惠后金额)
  875. TRADECHARGE float64 `json:"tradecharge" xorm:"TRADECHARGE"` // 成交手续费(买方)
  876. PAYFLAG int32 `json:"payflag" xorm:"PAYFLAG"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
  877. CREATETIME string `json:"createtime" xorm:"CREATETIME2"` // 创建时间
  878. PAYTIME string `json:"paytime" xorm:"PAYTIME2"` // 付款时间
  879. PAYLIMITEDTIME string `json:"paylimitedtime" xorm:"PAYLIMITEDTIME2"` // 支付期限
  880. OFFAMOUNT float64 `json:"offamount" xorm:"OFFAMOUNT"` // 优惠金额
  881. TRADEPRICE float64 `json:"tradeprice" xorm:"TRADEPRICE"` // 成交价格(价格)
  882. TRADEQTY float64 `json:"tradeqty" xorm:"TRADEQTY"` // 成交数量(数量)
  883. PAYAMOUNT float64 `json:"payamount" xorm:"PAYAMOUNT"` // 支付金额(金额)
  884. OPERATETYPE int32 `json:"operatetype" xorm:"OPERATETYPE"` // 买委托操作类型 - 1:正常下单 16:融资买入
  885. ADVANCERATIO float64 `json:"advanceratio" xorm:"ADVANCERATIO"` // 首付比率
  886. TRADETIME string `json:"tradetime"` // 成交时间
  887. QhjTradeEx `xorm:"extends"`
  888. IncludeSub int32 `json:"-"` // 是否包含子级 1-包含
  889. BeginDate string `json:"-"` // 开始交易日
  890. EndDate string `json:"-"` // 结束交易日
  891. FilterName string `json:"-"` // 模糊搜索
  892. FilterPayFlag string `json:"-"` // 付款标识
  893. }
  894. func (r *QhjMgrTradePayOrder) calc() {
  895. ZoomByDecimal(int(r.QTYDECIMALPLACE), &r.TRADEQTY)
  896. r.TRADETIME = r.CREATETIME
  897. r.dealConvert()
  898. }
  899. func (r *QhjMgrTradePayOrder) buildSql() string {
  900. var sqlId utils.SQLVal = "with k as" +
  901. " (select t.userid, wm_concat(t.logincode) logincode" +
  902. " from loginaccount t" +
  903. " group by t.userid)" +
  904. "select u.userid," +
  905. " u.accountname," +
  906. " k.logincode," +
  907. " u.subarealevelpath," +
  908. " ui.userinfotype," +
  909. " ui.mobile," +
  910. " g.goodsname," +
  911. " g.goodscode," +
  912. " g.goodunitid," +
  913. " g.qtydecimalplace," +
  914. " g.decimalplace," +
  915. " g.agreeunit," +
  916. " m.marketid," +
  917. " m.trademode," +
  918. " e.enumdicname," +
  919. " to_char(t.BUYORDERID) BUYORDERID2," +
  920. " to_char(t.TRADEID) TRADEID2," +
  921. " to_char(t.Paylimitedtime, 'yyyy-mm-dd hh24:mi:ss') Paylimitedtime2," +
  922. " to_char(t.PAYTIME, 'yyyy-mm-dd hh24:mi:ss') PAYTIME2," +
  923. " to_char(t.CREATETIME, 'yyyy-mm-dd hh24:mi:ss') CREATETIME2," +
  924. " t.*" +
  925. " from TRADE_PAYORDER t" +
  926. " inner join taaccount ta" +
  927. " on t.buyaccountid = ta.accountid" +
  928. " inner join useraccount u" +
  929. " on ta.relateduserid = u.userid" +
  930. " inner join userinfo ui" +
  931. " on u.userid = ui.userid" +
  932. " left join k" +
  933. " on u.userid = k.userid" +
  934. " left join goods g" +
  935. " on t.goodsid = g.goodsid" +
  936. " left join market m" +
  937. " on g.marketid = m.marketid" +
  938. " left join enumdicitem e" +
  939. " on e.enumitemname = g.goodunitid" +
  940. " and e.enumdiccode = 'goodsunit'" +
  941. " where 1 = 1"
  942. if r.IncludeSub == 1 {
  943. sqlId.JoinFormat(" and u.subarealevelpath like '%%,%v,%%'", r.USERID)
  944. } else {
  945. sqlId.And("u.parentuserid", r.USERID)
  946. }
  947. sqlId.AndEx("ui.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  948. sqlId.AndEx("m.TRADEMODE", r.TRADEMODE, r.TRADEMODE > 0)
  949. sqlId.AndEx("t.goodsid", r.GOODSID, r.GOODSID > 0)
  950. if len(r.FilterPayFlag) > 0 {
  951. sqlId.JoinFormat(" and t.PAYFLAG in(%v)", r.FilterPayFlag)
  952. }
  953. if len(r.BeginDate) > 0 {
  954. sqlId.JoinFormat(" and t.TRADEDATE >=%v", r.BeginDate)
  955. }
  956. if len(r.EndDate) > 0 {
  957. sqlId.JoinFormat(" and t.TRADEDATE <=%v", r.EndDate)
  958. }
  959. if len(r.FilterName) > 0 {
  960. sqlId.JoinFormat(" and (k.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName)
  961. }
  962. return sqlId.String()
  963. }
  964. // GetDataEx 获取待付款单据
  965. func (r *QhjMgrTradePayOrder) GetDataEx() (interface{}, error) {
  966. sData := make([]QhjMgrTradePayOrder, 0)
  967. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  968. for i := range sData {
  969. sData[i].calc()
  970. }
  971. return sData, err
  972. }
  973. // QhjMgrContract 千海金融资明细(合同)
  974. type QhjMgrContract struct {
  975. USERID int64 `json:"userid" xorm:"USERID"` // 用户ID
  976. SCFCONTRACTID string `json:"scfcontractid" xorm:"SCFCONTRACTID"` // SCF合同ID(310+Unix秒时间戳(10位)+xxxxxx)
  977. SCFCONTRACTTYPE int32 `json:"scfcontracttype" xorm:"SCFCONTRACTTYPE"` // 合同类型 - 1:仓单回购 2:仓单质押 3:合作套保 4:资金贷款 5:融资单
  978. GOODSID int32 `json:"goodsid" xorm:"GOODSID"` // 商品ID [5:融资单]
  979. CONTRACTCONFIRMTIME string `json:"contractconfirmtime" xorm:"CONTRACTCONFIRMTIME"` // 合同确认时间(时间)
  980. WRQTY float64 `json:"wrqty" xorm:"WRQTY"` // 仓单数量(数量)
  981. TRADEPRICE float64 `json:"tradeprice" xorm:"TRADEPRICE"` // 成交价格(成本价格)
  982. LENDERAMOUNT float64 `json:"lenderamount" xorm:"LENDERAMOUNT"` // 贷款金额(总额|订单总额)
  983. MARGINRATIO float64 `json:"marginratio" xorm:"MARGINRATIO"` // 保证金比率(首付比例)
  984. INITMARGIN float64 `json:"initmargin" xorm:"'INITMARGIN'"` // 初始保证金(首付款)
  985. RECOVEREDMARGIN float64 `json:"recoveredmargin" xorm:"'RECOVEREDMARGIN'"` // 已追缴保证金
  986. REMAINAMOUNT float64 `json:"remainamount" xorm:"'REMAINAMOUNT'"` // 合同剩余金额(融资额)
  987. TOTALINTEREST float64 `json:"totalinterest" xorm:"'TOTALINTEREST'"` // 已计总利息(利息)
  988. GOODSCODE string `json:"goodscode" xorm:"'GOODSCODE'"` // 商品代码
  989. GOODSNAME string `json:"goodsname" xorm:"'GOODSNAME'"` // 商品名称
  990. GOODUNITID int32 `json:"goodunitid" xorm:"'GOODUNITID'"` // 商品单位id
  991. CURRISKLEVEL int32 `json:"currisklevel" xorm:"'CURRISKLEVEL'"` // 风险级别 - 1:正常 2:追加货款 3:支付尾款
  992. RECKONRECOVERMARGIN float64 `json:"reckonrecovermargin" xorm:"'RECKONRECOVERMARGIN'"` // 结算应追缴保底金(结算时到过风险率时临时存储) - [仓单回购\仓单质押]
  993. DECIMALPLACE int32 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 商品报价小数位
  994. SCFCONTRACTSTATUS int32 `json:"scfcontractstatus" xorm:"'SCFCONTRACTSTATUS'"` // 合同状态 - 1:待确认 2:已确认 3:确认拒绝 4:已支付保证金 5:已激活 6:已违约 7:到期结束 8:延期结束 9:违约结束 10:已注销 11:已关闭 99:未提交
  995. LOGINCODE string `json:"logincode" xorm:"'LOGINCODE'"` // 账号(登录代码)
  996. USERINFOTYPE int32 `json:"userinfotype" xorm:"'USERINFOTYPE'"` // 用户类型 1-个人 2-企业
  997. MOBILE string `json:"mobile" xorm:"'MOBILE'"` // 电话号码(用户资料里的电话)
  998. TRADEDATE string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日
  999. PAYAMOUNT float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 已付(已付货款)
  1000. USERNAME string `json:"username" xorm:"'USERNAME'"` // 用户名称
  1001. ENUMDICNAME string `json:"enumdicname"` // 单位名称
  1002. BeginDate string `json:"-"` // 开始交易日
  1003. EndDate string `json:"-"` // 结束交易日
  1004. FilterName string `json:"-"` // 模糊搜索
  1005. FilterRiskLevel string `json:"-"` // 风险级别
  1006. }
  1007. func (r *QhjMgrContract) calc() {
  1008. r.USERNAME = mtpcache.GetUserNameByUserId(r.USERID)
  1009. r.ENUMDICNAME = mtpcache.GetEnumDicitemName(r.GOODUNITID)
  1010. // 已付(已付货款) = 已追缴保证金 + 初始保证金
  1011. r.PAYAMOUNT = r.RECOVEREDMARGIN + r.INITMARGIN
  1012. if r.SCFCONTRACTSTATUS == 10 || r.SCFCONTRACTSTATUS == 11 {
  1013. // 当合同关闭时, 利息重置为0
  1014. r.TOTALINTEREST = 0
  1015. }
  1016. if r.LOGINCODE == "" {
  1017. r.LOGINCODE = DecryptField(r.MOBILE)
  1018. }
  1019. }
  1020. func (r *QhjMgrContract) buildSql() string {
  1021. var sqlId utils.SQLVal = "with k as (select t.userid, wm_concat(t.logincode) logincode from loginaccount t group by t.userid)" +
  1022. "select t.borroweruserid userid," +
  1023. " to_char(t.scfcontractid) scfcontractid," +
  1024. " t.scfcontracttype," +
  1025. " t.goodsid," +
  1026. " to_char(t.contractconfirmtime, 'yyyy-mm-dd hh24:mi:ss') contractconfirmtime," +
  1027. " t.wrqty," +
  1028. " t.tradeprice," +
  1029. " t.lenderamount," +
  1030. " t.marginratio," +
  1031. " s.initmargin," +
  1032. " s.recoveredmargin," +
  1033. " s.remainamount," +
  1034. " s.totalinterest," +
  1035. " s.currisklevel," +
  1036. " s.reckonrecovermargin," +
  1037. " s.scfcontractstatus," +
  1038. " s.tradedate," +
  1039. " g.goodscode," +
  1040. " g.goodsname," +
  1041. " g.decimalplace," +
  1042. " g.goodunitid," +
  1043. " ui.userinfotype," +
  1044. " ui.mobile," +
  1045. " u.accountname," +
  1046. " k.logincode" +
  1047. " from scf_contract t" +
  1048. " left join scf_contractinfo s" +
  1049. " on t.scfcontractid = s.scfcontractid" +
  1050. " left join goods g" +
  1051. " on t.goodsid = g.goodsid" +
  1052. " left join userinfo ui on t.borroweruserid=ui.userid" +
  1053. " left join k on ui.userid=k.userid" +
  1054. " left join useraccount u on t.borroweruserid=u.userid" +
  1055. " where 1 = 1"
  1056. sqlId.AndEx("t.borroweruserid", r.USERID, r.USERID > 0)
  1057. sqlId.AndEx("ui.USERINFOTYPE", r.USERINFOTYPE, r.USERINFOTYPE > 0)
  1058. sqlId.AndEx("t.goodsid", r.GOODSID, r.GOODSID > 0)
  1059. if len(r.FilterRiskLevel) > 0 {
  1060. sqlId.JoinFormat(" and s.currisklevel in(%v)", r.FilterRiskLevel)
  1061. }
  1062. if len(r.BeginDate) > 0 {
  1063. sqlId.JoinFormat(" and s.TRADEDATE >=%v", r.BeginDate)
  1064. }
  1065. if len(r.EndDate) > 0 {
  1066. sqlId.JoinFormat(" and s.TRADEDATE <=%v", r.EndDate)
  1067. }
  1068. if len(r.FilterName) > 0 {
  1069. sqlId.JoinFormat(" and (k.logincode like '%%%v%%' or u.accountname like '%%%v%%')", r.FilterName, r.FilterName)
  1070. }
  1071. return sqlId.String()
  1072. }
  1073. // GetDataEx 获取融资明细(合同)
  1074. func (r *QhjMgrContract) GetDataEx() (interface{}, error) {
  1075. sData := make([]QhjMgrContract, 0)
  1076. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  1077. for i := range sData {
  1078. sData[i].calc()
  1079. }
  1080. return sData, err
  1081. }