ermcp3Report.go 107 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184
  1. /**
  2. * @Author: zou.yingbin
  3. * @Create : 2021/4/16 18:22
  4. * @Modify : 2021/4/16 18:22
  5. */
  6. package models
  7. import (
  8. "fmt"
  9. "mtp2_if/db"
  10. "mtp2_if/mtpcache"
  11. "mtp2_if/utils"
  12. "strings"
  13. )
  14. // Ermcp3ReportOPLog 报表合同操作记录通用查询
  15. type Ermcp3ReportOPLog struct {
  16. LOGID string `json:"logid" xorm:"'lOGID'"` // 流水ID(604+Unix秒时间戳(10位)+xxxxxx)
  17. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 - 1:套保计划 2:现货合同
  18. OPERATELOGTYPE int32 `json:"operatelogtype" xorm:"'OPERATELOGTYPE'"` // 操作流水类型 -
  19. RELATEDID string `json:"relatedid" xorm:"'RELATEDID'"` // 现货合同ID\套保计划
  20. LOGVALUE string `json:"logvalue" xorm:"'LOGVALUE'"` // 数值
  21. LOGDATETIME string `json:"logdatetime" xorm:"'LOGDATETIME'"` // 流水日期(时间)
  22. TRADEDATE string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
  23. APPLYID int64 `json:"applyid" xorm:"'APPLYID'"` // 操作人
  24. CONTRACTTYPE int32 `json:"contracttype" xorm:"'CONTRACTTYPE'"` // 现货合同类型 - 1:采购 -1:销售
  25. USERID int64 `json:"userid" xorm:"'USERID'"` // 机构ID
  26. RELATEDNO string `json:"relatedno" xorm:"'RELATEDNO'"` // 合同编号
  27. UNITID int32 `json:"-" xorm:"'UNITID'"` // 现货商品单位id
  28. ENUMDICNAME string `json:"enumdicName"` // 单位名称
  29. OPTYPENAME string `json:"optypename"` // 流水类型名称
  30. LOGTYPENAME string `json:"logtypename"` // 合同类型(名称)
  31. APPLYNAME string `json:"applyname"` // 操作人名称
  32. BRANDNAME string `json:"brandname" xorm:"'brandname'"` // 品牌名称
  33. DELIVERYGOODSID int32 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'"` // 现货品种id
  34. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货品种代码
  35. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货品种名称
  36. WRSTANDARDID int32 `json:"wrstandardid" xorm:"'wrstandardid'"` // 品类id
  37. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'wrstandardcode'"` // 品类代码
  38. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'wrstandardname'"` // 品类名称
  39. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"'SPOTGOODSBRANDID'"` // 品牌id
  40. LogTypeFilter string `json:"-"` // 查询日志类型, 逗号隔开(如 1,2,4)
  41. }
  42. // Calc 处理数据
  43. func (r *Ermcp3ReportOPLog) Calc() {
  44. r.ENUMDICNAME = mtpcache.GetEnumDicitemName(r.UNITID)
  45. r.APPLYNAME = mtpcache.GetUserNameByUserId(r.APPLYID)
  46. if r.APPLYNAME == "" {
  47. // APPLYID 可能存的是loginId
  48. r.APPLYNAME = mtpcache.GetLoginCodeByLoginId(r.APPLYID)
  49. }
  50. //1:点价价格 2:点价数量 3:结算量 4:其它费用 5:追加保证金 6溢短金额 7:调整金额 8:付款金额 9:收款金额 10:退款金额
  51. //11:收票金额 12:开票金额 13:提交审核(合同) 14:审核通过(合同) 15:审核拒绝(合同) 16:合同撤回 17:提交审核(计划)
  52. //18:审核通过(计划) 19:审核拒绝(计划) 20:计划撤回 21:正常完结(合同) 22:异常终止(合同) 23:退还保证金
  53. //24:采购入库 25:销售出库 26:生产入库 27:生产出库
  54. // 数据库注释与返回值映身关系: 结算量->确定量, 收款->收款金额, 退款->退款金额, 付款->付款金额, 收票->收票金额, 开票->开票金额
  55. sDes := []string{"点价价格", "点价数量", "确定量", "其它费用", "追加保证金", "溢短金额", "调整金额", "付款", "收款", "退款",
  56. "收票", "开票", "提交审核(合同)", "审核通过(合同)", "审核拒绝(合同)", "合同撤回", "提交审核(计划)",
  57. "审核通过(计划)", "审核拒绝(计划)", "计划撤回", "正常完结(合同)", "异常终止(合同)", "退还保证金",
  58. "采购入库", "销售出库", "生产入库", "生产出库"}
  59. if r.OPERATELOGTYPE >= 1 && r.OPERATELOGTYPE <= 27 {
  60. r.OPTYPENAME = sDes[r.OPERATELOGTYPE-1]
  61. }
  62. // 收款款项:采购合同的退款、销售合同的收款应用正数显示,付款款项:采购合同的付款、销售合同的退款应用负数显示
  63. if r.CONTRACTTYPE == 1 {
  64. r.LOGTYPENAME = "采购"
  65. // 采购合同/退款 正数
  66. if r.OPERATELOGTYPE == 10 && len(r.LOGVALUE) > 0 {
  67. if r.LOGVALUE[0] == '-' {
  68. r.LOGVALUE = r.LOGVALUE[1:]
  69. }
  70. }
  71. // 采购合同/付款 负数
  72. if r.OPERATELOGTYPE == 8 && len(r.LOGVALUE) > 0 {
  73. if r.LOGVALUE[0] != '-' {
  74. r.LOGVALUE = "-" + r.LOGVALUE
  75. }
  76. }
  77. } else if r.CONTRACTTYPE == -1 {
  78. r.LOGTYPENAME = "销售"
  79. // 销售合同/收款 正数
  80. if r.OPERATELOGTYPE == 9 && len(r.LOGVALUE) > 0 {
  81. if r.LOGVALUE[0] == '-' {
  82. r.LOGVALUE = r.LOGVALUE[1:]
  83. }
  84. }
  85. // 销售合同/退款 负数
  86. if r.OPERATELOGTYPE == 10 && len(r.LOGVALUE) > 0 {
  87. if r.LOGVALUE[0] != '-' {
  88. r.LOGVALUE = "-" + r.LOGVALUE
  89. }
  90. }
  91. }
  92. // 去除多余的0,最后4个0
  93. if r.LOGVALUE[len(r.LOGVALUE)-4:] == "0000" {
  94. r.LOGVALUE = r.LOGVALUE[:len(r.LOGVALUE)-4]
  95. }
  96. if r.BIZTYPE == 1 {
  97. r.LOGTYPENAME += "计划"
  98. } else if r.BIZTYPE == 2 {
  99. r.LOGTYPENAME += "合同"
  100. }
  101. }
  102. func (r *Ermcp3ReportOPLog) buildSql() string {
  103. var sqlId utils.SQLVal = "SELECT to_char(t.LOGID) LOGID," +
  104. " t.BIZTYPE," +
  105. " t.OPERATELOGTYPE," +
  106. " to_char(t.RELATEDID) RELATEDID," +
  107. " t.LOGVALUE," +
  108. " to_char(t.LOGDATETIME, 'yyyy-mm-dd hh24:mi:ss') LOGDATETIME," +
  109. " t.TRADEDATE," +
  110. " t.APPLYID," +
  111. " t.CONTRACTTYPE," +
  112. " t.USERID," +
  113. " t.wrstandardid," +
  114. " s.contractno relatedno," +
  115. " s.spotgoodsbrandid," +
  116. " g.deliverygoodsid," +
  117. " g.deliverygoodscode," +
  118. " g.deliverygoodsname," +
  119. " g.goodsunitid unitid," +
  120. " gb.dgfactoryitemvalue brandname," +
  121. " s.accountid," +
  122. " w.wrstandardcode," +
  123. " w.wrstandardname" +
  124. " FROM ERMCP_CONTRACTOPERATELOG t" +
  125. " inner join ermcp_spotcontract s" +
  126. " on t.RELATEDID = s.spotcontractid" +
  127. " left join deliverygoods g" +
  128. " on t.deliverygoodsid = g.deliverygoodsid" +
  129. " left join wrstandard w on t.wrstandardid=w.wrstandardid" +
  130. " left join dgfactoryitem gb" +
  131. " on s.spotgoodsbrandid = gb.dgfactoryitemid" +
  132. " WHERE t.biztype = 2"
  133. // 筛选条件
  134. sqlId.And("t.userid", r.USERID)
  135. sqlId.And("t.TRADEDATE", r.TRADEDATE)
  136. sqlId.AndEx("t.deliverygoodsid", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  137. sqlId.AndEx("t.wrstandardid", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  138. sqlId.AndEx("s.spotgoodsbrandid", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  139. if r.LogTypeFilter != "" {
  140. sqlId.Join(fmt.Sprintf(" and t.OPERATELOGTYPE in(%v)", r.LogTypeFilter))
  141. }
  142. return sqlId.String()
  143. }
  144. // GetDataEx 获取日志记录
  145. func (r *Ermcp3ReportOPLog) GetDataEx() (interface{}, error) {
  146. sData := make([]Ermcp3ReportOPLog, 0)
  147. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  148. for i := range sData {
  149. sData[i].Calc()
  150. }
  151. return sData, err
  152. }
  153. // Ermcp3ReckonAreaSpotSub 现货日报表(作废)
  154. type Ermcp3ReckonAreaSpotSub struct {
  155. RECKONDATE string `json:"reckondate" xorm:"'RECKONDATE'" form:"reckondate" binding:"required"` // 日照时期(yyyyMMdd)
  156. AREAUSERID int64 `json:"areauserid" xorm:"'AREAUSERID'" form:"userid" binding:"required"` // 账户所属机构
  157. ACCOUNTID int64 `json:"accountid" xorm:"'ACCOUNTID'" form:"accountid"` // 期货账户ID
  158. WRFACTORTYPEID int64 `json:"wrfactortypeid" xorm:"'WRFACTORTYPEID'"` // 仓单要素类型ID(212+Unix秒时间戳(10位)+xxxxxx)
  159. DELIVERYGOODSID int64 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'" form:"deliverygoodsid"` // 现货品种ID
  160. WRSTANDARDID int64 `json:"wrstandardid" xorm:"'WRSTANDARDID'" form:"wrstandardid"` // 现货品类ID
  161. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"'SPOTGOODSBRANDID'" form:"spotgoodsbrandid"` // 现货品牌ID
  162. ORIBUYPRICEDQTY float64 `json:"oribuypricedqty" xorm:"'ORIBUYPRICEDQTY'"` // 期初采购合同已定价数量
  163. ORISELLPRICEDQTY float64 `json:"orisellpricedqty" xorm:"'ORISELLPRICEDQTY'"` // 期初销售合同已定价数量
  164. BUYPRICEDQTY float64 `json:"buypricedqty" xorm:"'BUYPRICEDQTY'"` // 采购合同已定价数量
  165. SELLPRICEDQTY float64 `json:"sellpricedqty" xorm:"'SELLPRICEDQTY'"` // 销售合同已定价数量
  166. TOTALSPOTQTY float64 `json:"totalspotqty" xorm:"'TOTALSPOTQTY'"` // 现货头寸总量 = 采购合同已定价数量 - 销售合同已定价数量
  167. UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  168. TODAYBUYRECKONQTY float64 `json:"todaybuyreckonqty" xorm:"'TODAYBUYRECKONQTY'"` // 今日采购合同已确定数量
  169. TODAYSELLRECKONQTY float64 `json:"todaysellreckonqty" xorm:"'TODAYSELLRECKONQTY'"` // 今日销售合同已确定数量
  170. ORIBUYPRICEDAMOUNT float64 `json:"oribuypricedamount" xorm:"'ORIBUYPRICEDAMOUNT'"` // 期初采购合同已定价金额
  171. ORISELLPRICEDAMOUNT float64 `json:"orisellpricedamount" xorm:"'ORISELLPRICEDAMOUNT'"` // 期初销售合同已定价金额
  172. BUYPRICEDAMOUNT float64 `json:"buypricedamount" xorm:"'BUYPRICEDAMOUNT'"` // 采购合同已定价金额
  173. SELLPRICEDAMOUNT float64 `json:"sellpricedamount" xorm:"'SELLPRICEDAMOUNT'"` // 销售合同已定价金额
  174. ORIBUYRECKONQTY float64 `json:"oribuyreckonqty" xorm:"'ORIBUYRECKONQTY'"` // 期初采购合同交收量
  175. ORISELLRECKONQTY float64 `json:"orisellreckonqty" xorm:"'ORISELLRECKONQTY'"` // 期初销售合同交收量
  176. ORIBUYCONTRACTINQTY float64 `json:"oribuycontractinqty" xorm:"'ORIBUYCONTRACTINQTY'"` // 期初采购合同入库量
  177. ORISELLCONTRACTOUTQTY float64 `json:"orisellcontractoutqty" xorm:"'ORISELLCONTRACTOUTQTY'"` // 期初销售合同出库量
  178. ORIPRODUCEINQTY float64 `json:"oriproduceinqty" xorm:"'ORIPRODUCEINQTY'"` // 期初生产入库量
  179. ORIPRODUCEOUTQTY float64 `json:"oriproduceoutqty" xorm:"'ORIPRODUCEOUTQTY'"` // 期初生产出库量
  180. BUYRECKONQTY float64 `json:"buyreckonqty" xorm:"'BUYRECKONQTY'"` // 采购合同交收量
  181. SELLRECKONQTY float64 `json:"sellreckonqty" xorm:"'SELLRECKONQTY'"` // 销售合同交收量
  182. BUYCONTRACTINQTY float64 `json:"buycontractinqty" xorm:"'BUYCONTRACTINQTY'"` // 采购合同入库量
  183. SELLCONTRACTOUTQTY float64 `json:"sellcontractoutqty" xorm:"'SELLCONTRACTOUTQTY'"` // 销售合同出库量
  184. PRODUCEINQTY float64 `json:"produceinqty" xorm:"'PRODUCEINQTY'"` // 生产入库量
  185. PRODUCEOUTQTY float64 `json:"produceoutqty" xorm:"'PRODUCEOUTQTY'"` // 生产出库量
  186. ENUMDICNAME string `json:"enumdicname" xorm:"'ENUMDICNAME'"` // 现货商品单位名称
  187. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'wrstandardname'"` // 品类名称
  188. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'wrstandardcode'"` // 品类代码
  189. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'deliverygoodscode'"` // 现货商品代码
  190. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'deliverygoodsname'"` // 现货商品名称
  191. GOODSUNITID int32 `json:"goodsunitid" xorm:"'goodsunitid'"` // 现货商品单位id
  192. BRANDNAME string `json:"brandname" xorm:"'brandname'"` // 品牌名称
  193. ACCOUNTNAME string `json:"accountname" xorm:"'accountname'"` // 所属机构名称
  194. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 1-套保 2-套利
  195. CURRENCYID int32 `json:"currencyid" xorm:"'CURRENCYID'"` // 币种id
  196. CURRENCYNAME string `json:"currencyname"` // 币种名称
  197. TOTALBUYPRICEDQTY float64 `json:"totalbuypricedqty"` // 采购定价量 = 期末 - 期初
  198. TOTALSELLPRICEDQTY float64 `json:"totalsellpricedqty"` // 销售定价量 = 期末 - 期初
  199. BeginDate string `json:"-"` // 开始日期
  200. EndDate string `json:"-"` // 结束日期
  201. }
  202. func (r *Ermcp3ReckonAreaSpotSub) calc() {
  203. r.TOTALBUYPRICEDQTY = r.BUYPRICEDQTY - r.ORIBUYPRICEDQTY
  204. r.TOTALSELLPRICEDQTY = r.SELLPRICEDQTY - r.ORISELLPRICEDQTY
  205. r.CURRENCYNAME = mtpcache.GetCurrencyName(r.CURRENCYID)
  206. }
  207. func (r *Ermcp3ReckonAreaSpotSub) buildSql() string {
  208. var sqlId utils.SQLVal = "SELECT t.ORIBUYRECKONQTY," +
  209. " t.ORISELLRECKONQTY," +
  210. " t.ORIBUYCONTRACTINQTY," +
  211. " t.ORISELLCONTRACTOUTQTY," +
  212. " t.ORIPRODUCEINQTY," +
  213. " t.ORIPRODUCEOUTQTY," +
  214. " t.BUYRECKONQTY," +
  215. " t.SELLRECKONQTY," +
  216. " t.BUYCONTRACTINQTY," +
  217. " t.SELLCONTRACTOUTQTY," +
  218. " t.PRODUCEINQTY," +
  219. " t.PRODUCEOUTQTY," +
  220. " t.Reckondate," +
  221. " t.AREAUSERID," +
  222. " t.ACCOUNTID," +
  223. " t.WRFACTORTYPEID," +
  224. " t.DELIVERYGOODSID," +
  225. " t.WRSTANDARDID," +
  226. " t.SPOTGOODSBRANDID," +
  227. " t.ORIBUYPRICEDQTY," +
  228. " t.ORISELLPRICEDQTY," +
  229. " t.BUYPRICEDQTY," +
  230. " t.SELLPRICEDQTY," +
  231. " t.TOTALSPOTQTY," +
  232. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  233. " t.TODAYBUYRECKONQTY," +
  234. " t.TODAYSELLRECKONQTY," +
  235. " t.ORIBUYPRICEDAMOUNT," +
  236. " t.ORISELLPRICEDAMOUNT," +
  237. " t.BUYPRICEDAMOUNT," +
  238. " t.SELLPRICEDAMOUNT," +
  239. " t.currencyid," +
  240. " t.biztype," +
  241. " w.wrstandardname," +
  242. " w.wrstandardcode," +
  243. " g.deliverygoodscode," +
  244. " g.deliverygoodsname," +
  245. " g.goodsunitid," +
  246. " d.dgfactoryitemvalue brandname," +
  247. " u.accountname," +
  248. " e.enumdicname" +
  249. " FROM RECKON_ERMCP_AREASPOTSUB t" +
  250. " LEFT JOIN WRSTANDARD w" +
  251. " on t.wrstandardid = w.wrstandardid" +
  252. " LEFT JOIN DELIVERYGOODS g" +
  253. " on t.deliverygoodsid = g.deliverygoodsid" +
  254. " LEFT JOIN DGFACTORYITEM d" +
  255. " on t.spotgoodsbrandid = d.dgfactoryitemid" +
  256. " LEFT JOIN USERACCOUNT u" +
  257. " on t.areauserid = u.userid" +
  258. " LEFT JOIN ENUMDICITEM e" +
  259. " on g.goodsunitid = e.enumitemname" +
  260. " and e.enumdiccode = 'goodsunit'" +
  261. " and e.enumitemstatus = 1" +
  262. " WHERE 1 = 1"
  263. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  264. sqlId.AndEx("t.ACCOUNTID", r.ACCOUNTID, r.ACCOUNTID > 0)
  265. sqlId.AndEx("t.deliverygoodsid", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  266. sqlId.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  267. sqlId.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  268. if r.RECKONDATE != "" {
  269. sqlId.And("t.RECKONDATE", r.RECKONDATE)
  270. } else if r.BeginDate != "" && r.BeginDate == r.EndDate {
  271. sqlId.And("t.RECKONDATE", r.BeginDate)
  272. } else {
  273. if r.BeginDate != "" {
  274. sqlId.BiggerOrEq("t.RECKONDATE", r.BeginDate)
  275. }
  276. if r.EndDate != "" {
  277. sqlId.LessOrEq("t.RECKONDATE", r.EndDate)
  278. }
  279. }
  280. sqlId.Join(" order by t.RECKONDATE")
  281. return sqlId.String()
  282. }
  283. // GetDataEx 获取现货日报表
  284. func (r *Ermcp3ReckonAreaSpotSub) GetDataEx() (interface{}, error) {
  285. sData := make([]Ermcp3ReckonAreaSpotSub, 0)
  286. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  287. for i := range sData {
  288. sData[i].calc()
  289. }
  290. return sData, err
  291. }
  292. // Ermcp3ReportAreaSpotSub 现货分类月报表(作废)
  293. type Ermcp3ReportAreaSpotSub struct {
  294. ORIBUYRECKONQTY float64 `json:"oribuyreckonqty" xorm:"'ORIBUYRECKONQTY'"` // 期初采购合同交收量【期初】
  295. ORISELLRECKONQTY float64 `json:"orisellreckonqty" xorm:"'ORISELLRECKONQTY'"` // 期初销售合同交收量【期初】
  296. ORIBUYCONTRACTINQTY float64 `json:"oribuycontractinqty" xorm:"'ORIBUYCONTRACTINQTY'"` // 期初采购合同入库量【期初】
  297. ORISELLCONTRACTOUTQTY float64 `json:"orisellcontractoutqty" xorm:"'ORISELLCONTRACTOUTQTY'"` // 期初销售合同出库量【期初】
  298. ORIPRODUCEINQTY float64 `json:"oriproduceinqty" xorm:"'ORIPRODUCEINQTY'"` // 期初生产入库量【期初】
  299. ORIPRODUCEOUTQTY float64 `json:"oriproduceoutqty" xorm:"'ORIPRODUCEOUTQTY'"` // 期初生产出库量【期初】
  300. BUYRECKONQTY float64 `json:"buyreckonqty" xorm:"'BUYRECKONQTY'"` // 采购合同交收量【期末】
  301. SELLRECKONQTY float64 `json:"sellreckonqty" xorm:"'SELLRECKONQTY'"` // 销售合同交收量【期末】
  302. BUYCONTRACTINQTY float64 `json:"buycontractinqty" xorm:"'BUYCONTRACTINQTY'"` // 采购合同入库量【期末】
  303. SELLCONTRACTOUTQTY float64 `json:"sellcontractoutqty" xorm:"'SELLCONTRACTOUTQTY'"` // 销售合同出库量【期末】
  304. PRODUCEINQTY float64 `json:"produceinqty" xorm:"'PRODUCEINQTY'"` // 生产入库量【期末】
  305. PRODUCEOUTQTY float64 `json:"produceoutqty" xorm:"'PRODUCEOUTQTY'"` // 生产出库量【期末】
  306. CYCLETIME string `json:"cycletime" xorm:"'CYCLETIME'" form:"cycletime"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  307. CYCLETYPE int32 `json:"cycletype" xorm:"'CYCLETYPE'" form:"cycletype"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  308. AREAUSERID int64 `json:"areauserid" xorm:"'AREAUSERID'" form:"userid" binding:"required"` // 账户所属机构
  309. ACCOUNTID int64 `json:"accountid" xorm:"'ACCOUNTID'" form:"accountid"` // 期货账户ID
  310. WRFACTORTYPEID int64 `json:"wrfactortypeid" xorm:"'WRFACTORTYPEID'"` // 仓单要素类型ID(212+Unix秒时间戳(10位)+xxxxxx)
  311. DELIVERYGOODSID int64 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'" form:"deliverygoodsid"` // 现货品种ID
  312. WRSTANDARDID int64 `json:"wrstandardid" xorm:"'WRSTANDARDID'" form:"wrstandardid"` // 品类ID
  313. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"'SPOTGOODSBRANDID'" form:"spotgoodsbrandid"` // 现货品牌ID
  314. ORIBUYPRICEDQTY float64 `json:"oribuypricedqty" xorm:"'ORIBUYPRICEDQTY'"` // 期初采购合同已定价数量【期初】
  315. ORISELLPRICEDQTY float64 `json:"orisellpricedqty" xorm:"'ORISELLPRICEDQTY'"` // 期初销售合同已定价数量【期初】
  316. BUYPRICEDQTY float64 `json:"buypricedqty" xorm:"'BUYPRICEDQTY'"` // 采购合同已定价数量【期末】
  317. SELLPRICEDQTY float64 `json:"sellpricedqty" xorm:"'SELLPRICEDQTY'"` // 销售合同已定价数量【期末】
  318. TOTALSPOTQTY float64 `json:"totalspotqty" xorm:"'TOTALSPOTQTY'"` // 现货头寸总量 = 采购合同已定价数量 - 销售合同已定价数量【期末】
  319. UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  320. TODAYBUYRECKONQTY float64 `json:"todaybuyreckonqty" xorm:"'TODAYBUYRECKONQTY'"` // 今日采购合同已确定数量【汇总】
  321. TODAYSELLRECKONQTY float64 `json:"todaysellreckonqty" xorm:"'TODAYSELLRECKONQTY'"` // 今日销售合同已确定数量【汇总】
  322. ORIBUYPRICEDAMOUNT float64 `json:"oribuypricedamount" xorm:"'ORIBUYPRICEDAMOUNT'"` // 期初采购合同已定价金额【期初】
  323. ORISELLPRICEDAMOUNT float64 `json:"orisellpricedamount" xorm:"'ORISELLPRICEDAMOUNT'"` // 期初销售合同已定价金额【期初】
  324. BUYPRICEDAMOUNT float64 `json:"buypricedamount" xorm:"'BUYPRICEDAMOUNT'"` // 采购合同已定价金额【期末】
  325. SELLPRICEDAMOUNT float64 `json:"sellpricedamount" xorm:"'SELLPRICEDAMOUNT'"` // 销售合同已定价金额【期末】
  326. ENUMDICNAME string `json:"enumdicname" xorm:"'ENUMDICNAME'"` // 现货商品单位名称
  327. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'wrstandardname'"` // 品类名称
  328. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'wrstandardcode'"` // 品类代码
  329. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'deliverygoodscode'"` // 现货商品代码
  330. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'deliverygoodsname'"` // 现货商品名称
  331. GOODSUNITID int32 `json:"goodsunitid" xorm:"'goodsunitid'"` // 现货商品单位id
  332. BRANDNAME string `json:"brandname" xorm:"'brandname'"` // 品牌名称
  333. ACCOUNTNAME string `json:"accountname" xorm:"'accountname'"` // 所属机构名称
  334. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 1-套保 2-套利
  335. CURRENCYID int32 `json:"currencyid" xorm:"'CURRENCYID'"` // 币种id
  336. CURRENCYNAME string `json:"currencyname"` // 币种名称
  337. TOTALBUYPRICEDQTY float64 `json:"totalbuypricedqty"` // 采购定价量 = 期末 - 期初
  338. TOTALSELLPRICEDQTY float64 `json:"totalsellpricedqty"` // 销售定价量 = 期末 - 期初
  339. }
  340. func (r *Ermcp3ReportAreaSpotSub) calc() {
  341. r.CURRENCYNAME = mtpcache.GetCurrencyName(r.CURRENCYID)
  342. r.TOTALBUYPRICEDQTY = r.BUYPRICEDQTY - r.ORIBUYPRICEDQTY
  343. r.TOTALSELLPRICEDQTY = r.SELLPRICEDQTY - r.ORISELLPRICEDQTY
  344. }
  345. func (r *Ermcp3ReportAreaSpotSub) buildSql() string {
  346. var sqlId utils.SQLVal = "SELECT t.ORIBUYRECKONQTY," +
  347. " t.ORISELLRECKONQTY," +
  348. " t.ORIBUYCONTRACTINQTY," +
  349. " t.ORISELLCONTRACTOUTQTY," +
  350. " t.ORIPRODUCEINQTY," +
  351. " t.ORIPRODUCEOUTQTY," +
  352. " t.BUYRECKONQTY," +
  353. " t.SELLRECKONQTY," +
  354. " t.BUYCONTRACTINQTY," +
  355. " t.SELLCONTRACTOUTQTY," +
  356. " t.PRODUCEINQTY," +
  357. " t.PRODUCEOUTQTY," +
  358. " t.CYCLETIME," +
  359. " t.CYCLETYPE," +
  360. " t.AREAUSERID," +
  361. " t.ACCOUNTID," +
  362. " t.WRFACTORTYPEID," +
  363. " t.DELIVERYGOODSID," +
  364. " t.WRSTANDARDID," +
  365. " t.SPOTGOODSBRANDID," +
  366. " t.ORIBUYPRICEDQTY," +
  367. " t.ORISELLPRICEDQTY," +
  368. " t.BUYPRICEDQTY," +
  369. " t.SELLPRICEDQTY," +
  370. " t.TOTALSPOTQTY," +
  371. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  372. " t.TODAYBUYRECKONQTY," +
  373. " t.TODAYSELLRECKONQTY," +
  374. " t.ORIBUYPRICEDAMOUNT," +
  375. " t.ORISELLPRICEDAMOUNT," +
  376. " t.BUYPRICEDAMOUNT," +
  377. " t.SELLPRICEDAMOUNT," +
  378. " t.currencyid," +
  379. " t.biztype," +
  380. " w.wrstandardname," +
  381. " w.wrstandardcode," +
  382. " g.deliverygoodscode," +
  383. " g.deliverygoodsname," +
  384. " g.goodsunitid," +
  385. " d.dgfactoryitemvalue brandname," +
  386. " u.accountname," +
  387. " e.enumdicname" +
  388. " FROM REPORT_ERMCP_AREASPOTSUB t" +
  389. " LEFT JOIN WRSTANDARD w on t.wrstandardid=w.wrstandardid" +
  390. " LEFT JOIN DELIVERYGOODS g on t.deliverygoodsid=g.deliverygoodsid" +
  391. " LEFT JOIN DGFACTORYITEM d on t.spotgoodsbrandid=d.dgfactoryitemid" +
  392. " LEFT JOIN USERACCOUNT u on t.areauserid=u.userid" +
  393. " LEFT JOIN ENUMDICITEM e on g.goodsunitid=e.enumitemname and e.enumdiccode='goodsunit' and e.enumitemstatus=1" +
  394. " WHERE 1 = 1"
  395. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  396. sqlId.And("t.cycletype", r.CYCLETYPE)
  397. sqlId.And("t.cycletime", r.CYCLETIME)
  398. sqlId.AndEx("t.ACCOUNTID", r.ACCOUNTID, r.ACCOUNTID > 0)
  399. sqlId.AndEx("t.deliverygoodsid", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  400. sqlId.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  401. sqlId.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  402. return sqlId.String()
  403. }
  404. // GetDataEx 获取现货分类报表
  405. func (r *Ermcp3ReportAreaSpotSub) GetDataEx() (interface{}, error) {
  406. sData := make([]Ermcp3ReportAreaSpotSub, 0)
  407. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  408. for i := range sData {
  409. sData[i].calc()
  410. }
  411. return sData, err
  412. }
  413. // Ermcp3ExpourseReport 敞口报表
  414. type Ermcp3ExpourseReport struct {
  415. RECKONDATE string `json:"reckondate" xorm:"'RECKONDATE'"` // 日照时期(yyyyMMdd)
  416. CYCLETIME string `json:"cycletime" xorm:"'CYCLETIME'"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  417. CYCLETYPE int32 `json:"cycletype" xorm:"'CYCLETYPE'"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  418. ORITOTALSPOTQTY float64 `json:"oritotalspotqty" xorm:"'ORITOTALSPOTQTY'"` // 期初现货头寸总量
  419. ORITOTALFUTUREQTY float64 `json:"oritotalfutureqty" xorm:"'ORITOTALFUTUREQTY'"` // 期初期货头寸总量
  420. ORITOTALEXPOSURE float64 `json:"oritotalexposure" xorm:"'ORITOTALEXPOSURE'"` // 期初实时总敞口
  421. ORINEEDHEDGEEXPOSOURE float64 `json:"orineedhedgeexposoure" xorm:"'ORINEEDHEDGEEXPOSOURE'"` // 期初应套保敞口
  422. ORIHEDGEQTY float64 `json:"orihedgeqty" xorm:"'ORIHEDGEQTY'"` // 期初套保量
  423. ORIARBITRAGEQTY float64 `json:"oriarbitrageqty" xorm:"'ORIARBITRAGEQTY'"` // 期初套利量
  424. ORINEEDHEDGEQTY float64 `json:"orineedhedgeqty" xorm:"'ORINEEDHEDGEQTY'"` // 期初应套保量
  425. ORINEEDARBITRAGEQTY float64 `json:"orineedarbitrageqty" xorm:"'ORINEEDARBITRAGEQTY'"` // 期初应套利量
  426. ORITOTALNEEDHEDGEQTY float64 `json:"oritotalneedhedgeqty" xorm:"'ORITOTALNEEDHEDGEQTY'"` // 期初应套保总量
  427. MIDDLEGOODSID int64 `json:"middlegoodsid" xorm:"'MIDDLEGOODSID'"` // 套保品种ID
  428. AREAUSERID int64 `json:"areauserid" xorm:"'AREAUSERID'"` // 所属机构\交易用户ID
  429. ACCOUNTID int64 `json:"accountid" xorm:"'ACCOUNTID'"` // 期货账户ID (作废, 默认为0)
  430. ORIBUYPLANQTY float64 `json:"oribuyplanqty" xorm:"'ORIBUYPLANQTY'"` // 期初采购计划数量
  431. ORIBUYPRICEDQTY float64 `json:"oribuypricedqty" xorm:"'ORIBUYPRICEDQTY'"` // 期初采购合同已定价数量
  432. ORISELLPLANQTY float64 `json:"orisellplanqty" xorm:"'ORISELLPLANQTY'"` // 期初销售计划数量
  433. ORISELLPRICEDQTY float64 `json:"orisellpricedqty" xorm:"'ORISELLPRICEDQTY'"` // 期初销售合同已定价数量
  434. ORIBUYFUTUREQTY float64 `json:"oribuyfutureqty" xorm:"'ORIBUYFUTUREQTY'"` // 期初买入期货数量
  435. ORISELLFUTUREQTY float64 `json:"orisellfutureqty" xorm:"'ORISELLFUTUREQTY'"` // 期初卖出期货数量
  436. BUYPLANQTY float64 `json:"buyplanqty" xorm:"'BUYPLANQTY'"` // 采购计划数量
  437. BUYPRICEDQTY float64 `json:"buypricedqty" xorm:"'BUYPRICEDQTY'"` // 采购合同已定价数量
  438. SELLPLANQTY float64 `json:"sellplanqty" xorm:"'SELLPLANQTY'"` // 销售计划数量
  439. SELLPRICEDQTY float64 `json:"sellpricedqty" xorm:"'SELLPRICEDQTY'"` // 销售合同已定价数量
  440. BUYFUTUREQTY float64 `json:"buyfutureqty" xorm:"'BUYFUTUREQTY'"` // 买入期货数量
  441. SELLFUTUREQTY float64 `json:"sellfutureqty" xorm:"'SELLFUTUREQTY'"` // 卖出期货数量
  442. TOTALSPOTQTY float64 `json:"totalspotqty" xorm:"'TOTALSPOTQTY'"` // 现货头寸总量
  443. TOTALFUTUREQTY float64 `json:"totalfutureqty" xorm:"'TOTALFUTUREQTY'"` // 期货头寸总量(期货总量)
  444. TOTALEXPOSURE float64 `json:"totalexposure" xorm:"'TOTALEXPOSURE'"` // 实时总敞口(总敞口)
  445. TOTALHEDGERATIO float64 `json:"totalhedgeratio" xorm:"'TOTALHEDGERATIO'"` // 敞口比例
  446. TOTALNEEDHEDGEQTY float64 `json:"totalneedhedgeqty" xorm:"'TOTALNEEDHEDGEQTY'"` // 应套保总量(现货应套保总量)
  447. NEEDHEDGEEXPOSOURE float64 `json:"needhedgeexposoure" xorm:"'NEEDHEDGEEXPOSOURE'"` // 应套保敞口(套保敞口)
  448. NEEDHEDGERATIO float64 `json:"needhedgeratio" xorm:"'NEEDHEDGERATIO'"` // 应套保敞口比例
  449. UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  450. HEDGEQTY float64 `json:"hedgeqty" xorm:"'HEDGEQTY'"` // 套保量
  451. ARBITRAGEQTY float64 `json:"arbitrageqty" xorm:"'ARBITRAGEQTY'"` // 套利量
  452. NEEDHEDGEQTY float64 `json:"needhedgeqty" xorm:"'NEEDHEDGEQTY'"` // 应套保量
  453. NEEDARBITRAGEQTY float64 `json:"needarbitrageqty" xorm:"'NEEDARBITRAGEQTY'"` // 应套利量
  454. MIDDLEGOODSNAME string `json:"middlegoodsname" xorm:"'MIDDLEGOODSNAME'"` // 套保商品名称
  455. MIDDLEGOODSCODE string `json:"middlgoodscode" xorm:"'MIDDLEGOODSCODE'"` // 套保商品代码
  456. UNITID int32 `json:"unitid" xorm:"'UNITID'"` // 单位id
  457. MGNEEDHEDGERATIO float64 `json:"mgneedhedgeratio" xorm:"'MGNEEDHEDGERATIO'"` // 套保比例(套保品的)
  458. NEEDARBITRAGERATIO float64 `json:"needarbitrageratio" xorm:"'NEEDARBITRAGERATIO'"` // 套利比例(套保品的)
  459. ENUMDICNAME string `json:"enumdicname"` // 单位名称
  460. ACCOUNTNAME string `json:"accountname"` // 机构名称
  461. DiffSpotQty float64 `json:"diffspotqty"` // 变动量(现货)
  462. DiffMgQtyA float64 `json:"diffmgqtya"` // 套保变动量
  463. DiffMgQtyB float64 `json:"diffmgqtyb"` // 套利变动量
  464. DiffFutuQty float64 `json:"difffutuqty"` // 变动量(期货)
  465. DiffQty float64 `json:"diffqty"` // 变动量(总敞口)
  466. DiffHedgeQty float64 `json:"diffhedgeqty"` // 变动量(现货应套保总量)
  467. DiffExposure float64 `json:"diffexposure"` // 变动量(套保敞口)
  468. QueryType int32 `json:"-"` // 查询类型 1-报表
  469. BeginDate string `json:"begindate"` // 开始交易日
  470. EndDate string `json:"enddate"` // 结束交易日
  471. }
  472. func (r *Ermcp3ExpourseReport) calc() {
  473. r.ENUMDICNAME = mtpcache.GetEnumDicitemName(r.UNITID)
  474. r.ACCOUNTNAME = mtpcache.GetUserNameByUserId(r.AREAUSERID)
  475. // 变动量(现货) = 现货头寸总量 - 期初现货头寸总量
  476. r.DiffSpotQty = r.TOTALSPOTQTY - r.ORITOTALSPOTQTY
  477. // 套保变动量 = 套保量 - 期初套保量
  478. r.DiffMgQtyA = r.HEDGEQTY - r.ORIHEDGEQTY
  479. // 套利变动量 = 套利量 - 期初套利量
  480. r.DiffMgQtyB = r.ARBITRAGEQTY - r.ORIARBITRAGEQTY
  481. // 变动量(期货) = (买入 - 买入期初) - (卖出 - 卖出期初)
  482. r.DiffFutuQty = (r.BUYFUTUREQTY - r.ORIBUYFUTUREQTY) - (r.SELLFUTUREQTY - r.ORISELLFUTUREQTY)
  483. // 变动量(敞口) = 实时敞口 - 期初实时敞口
  484. r.DiffQty = r.TOTALEXPOSURE - r.ORITOTALEXPOSURE
  485. // 变动量(现货应套保总量)
  486. r.DiffHedgeQty = r.TOTALNEEDHEDGEQTY - r.ORITOTALNEEDHEDGEQTY
  487. // 变动量(套保敞口)
  488. r.DiffExposure = r.NEEDHEDGEEXPOSOURE - r.ORINEEDHEDGEEXPOSOURE
  489. }
  490. func (r *Ermcp3ExpourseReport) buildSql() string {
  491. if r.CYCLETYPE == 0 {
  492. return r.buildSqlDay()
  493. }
  494. return r.buildSqlCycle()
  495. }
  496. func (r *Ermcp3ExpourseReport) buildSqlDay() string {
  497. var sqlId utils.SQLVal = "SELECT t.ORITOTALSPOTQTY," +
  498. " t.ORITOTALFUTUREQTY," +
  499. " t.ORITOTALEXPOSURE," +
  500. " t.ORINEEDHEDGEEXPOSOURE," +
  501. " t.ORIHEDGEQTY," +
  502. " t.ORIARBITRAGEQTY," +
  503. " t.ORINEEDHEDGEQTY," +
  504. " t.ORINEEDARBITRAGEQTY," +
  505. " t.ORITOTALNEEDHEDGEQTY," +
  506. " t.RECKONDATE," +
  507. " t.MIDDLEGOODSID," +
  508. " t.AREAUSERID," +
  509. " t.ACCOUNTID," +
  510. " t.ORIBUYPLANQTY," +
  511. " t.ORIBUYPRICEDQTY," +
  512. " t.ORISELLPLANQTY," +
  513. " t.ORISELLPRICEDQTY," +
  514. " t.ORIBUYFUTUREQTY," +
  515. " t.ORISELLFUTUREQTY," +
  516. " t.BUYPLANQTY," +
  517. " t.BUYPRICEDQTY," +
  518. " t.SELLPLANQTY," +
  519. " t.SELLPRICEDQTY," +
  520. " t.BUYFUTUREQTY," +
  521. " t.SELLFUTUREQTY," +
  522. " t.TOTALSPOTQTY," +
  523. " t.TOTALFUTUREQTY," +
  524. " t.TOTALEXPOSURE," +
  525. " t.TOTALHEDGERATIO," +
  526. " t.TOTALNEEDHEDGEQTY," +
  527. " t.NEEDHEDGEEXPOSOURE," +
  528. " t.NEEDHEDGERATIO," +
  529. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  530. " t.HEDGEQTY," +
  531. " t.ARBITRAGEQTY," +
  532. " t.NEEDHEDGEQTY," +
  533. " t.NEEDARBITRAGEQTY," +
  534. " g.middlegoodsname," +
  535. " g.middlegoodscode," +
  536. " g.goodsunitid unitid," +
  537. " g.needhedgeratio MGNEEDHEDGERATIO," +
  538. " g.needarbitrageratio" +
  539. " FROM RECKON_ERMCP_AREAEXPOSURE t" +
  540. " LEFT JOIN ERMS_MIDDLEGOODS g" +
  541. " on t.middlegoodsid = g.middlegoodsid" +
  542. " WHERE 1 = 1"
  543. sqlId.AndEx("t.AREAUSERID", r.AREAUSERID, r.AREAUSERID > 0)
  544. if r.QueryType == 1 {
  545. sqlId.And("t.RECKONDATE", r.RECKONDATE)
  546. } else if r.QueryType == 2 {
  547. sqlId.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  548. }
  549. return sqlId.String()
  550. }
  551. func (r *Ermcp3ExpourseReport) buildSqlCycle() string {
  552. var sqlId utils.SQLVal = "SELECT t.cycletime," +
  553. " t.cycletype," +
  554. " t.ORITOTALSPOTQTY," +
  555. " t.ORITOTALFUTUREQTY," +
  556. " t.ORITOTALEXPOSURE," +
  557. " t.ORINEEDHEDGEEXPOSOURE," +
  558. " t.ORIHEDGEQTY," +
  559. " t.ORIARBITRAGEQTY," +
  560. " t.ORINEEDHEDGEQTY," +
  561. " t.ORINEEDARBITRAGEQTY," +
  562. " t.ORITOTALNEEDHEDGEQTY," +
  563. " t.MIDDLEGOODSID," +
  564. " t.AREAUSERID," +
  565. " t.ACCOUNTID," +
  566. " t.ORIBUYPLANQTY," +
  567. " t.ORIBUYPRICEDQTY," +
  568. " t.ORISELLPLANQTY," +
  569. " t.ORISELLPRICEDQTY," +
  570. " t.ORIBUYFUTUREQTY," +
  571. " t.ORISELLFUTUREQTY," +
  572. " t.BUYPLANQTY," +
  573. " t.BUYPRICEDQTY," +
  574. " t.SELLPLANQTY," +
  575. " t.SELLPRICEDQTY," +
  576. " t.BUYFUTUREQTY," +
  577. " t.SELLFUTUREQTY," +
  578. " t.TOTALSPOTQTY," +
  579. " t.TOTALFUTUREQTY," +
  580. " t.TOTALEXPOSURE," +
  581. " t.TOTALHEDGERATIO," +
  582. " t.TOTALNEEDHEDGEQTY," +
  583. " t.NEEDHEDGEEXPOSOURE," +
  584. " t.NEEDHEDGERATIO," +
  585. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  586. " t.HEDGEQTY," +
  587. " t.ARBITRAGEQTY," +
  588. " t.NEEDHEDGEQTY," +
  589. " t.NEEDARBITRAGEQTY," +
  590. " g.middlegoodsname," +
  591. " g.middlegoodscode," +
  592. " g.goodsunitid unitid," +
  593. " g.needhedgeratio MGNEEDHEDGERATIO," +
  594. " g.needarbitrageratio" +
  595. " FROM REPORT_ERMCP_AREAEXPOSURE t" +
  596. " LEFT JOIN ERMS_MIDDLEGOODS g" +
  597. " on t.middlegoodsid = g.middlegoodsid" +
  598. " WHERE 1 = 1"
  599. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  600. sqlId.And("t.CYCLETYPE", r.CYCLETYPE)
  601. sqlId.And("t.CYCLETIME", r.CYCLETIME)
  602. return sqlId.String()
  603. }
  604. // GetDataEx 获取敞报表
  605. func (r *Ermcp3ExpourseReport) GetDataEx() (interface{}, error) {
  606. sData := make([]Ermcp3ExpourseReport, 0)
  607. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  608. for i := range sData {
  609. sData[i].calc()
  610. sData[i].BeginDate = r.BeginDate
  611. sData[i].EndDate = r.EndDate
  612. }
  613. return sData, err
  614. }
  615. // Ermcp3ExposureContractDetail 敞口合同明细
  616. type Ermcp3ExposureContractDetail struct {
  617. MIDDLEGOODSID int32 `json:"middlegoodsid" xorm:"'MIDDLEGOODSID'"` // 套保品种id
  618. DELIVERYGOODSID int32 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'"` // 现货商品id
  619. CONVERTRATIO float64 `json:"convertratio" xorm:"'CONVERTRATIO'"` // 折算系数(套保品种)
  620. USERID int64 `json:"userid" xorm:"'USERID'"` // 机构id
  621. SPOTCONTRACTID string `json:"spotcontractid" xorm:"'SPOTCONTRACTID'"` // 合同id
  622. CONTRACTNO string `json:"contractno" xorm:"'CONTRACTNO'"` // 合同编号
  623. CONTRACTTYPE int32 `json:"contracttype" xorm:"'CONTRACTTYPE'"` // 现货合同类型 - 1:采购 -1:销售
  624. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 1-套保 2-套利
  625. BUYUSERID int64 `json:"buyuserid" xorm:"'BUYUSERID'"` // 采购方id
  626. SELLUSERID int64 `json:"selluserid" xorm:"'SELLUSERID'"` // 销售方id
  627. QTY float64 `json:"qty" xorm:"'QTY'"` // 合同量
  628. PRICEDQTY float64 `json:"pricedqty" xorm:"'PRICEDQTY'"` // 已定价量
  629. WRSTANDARDID int32 `json:"wrstandardid" xorm:"'WRSTANDARDID'"` // 品类id
  630. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'WRSTANDARDNAME'"` // 品类名称
  631. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'WRSTANDARDCODE'"` // 品类代码
  632. UNITID int32 `json:"unitid" xorm:"'UNITID'"` // 品类单位id
  633. MIDDLEGOODSNAME string `json:"middlegoodsname" xorm:"'MIDDLEGOODSNAME'"` // 套保品种名称
  634. MIDDLEGOODSCODE string `json:"middlegoodscode" xorm:"'MIDDLEGOODSCODE'"` // 套保品种代码
  635. GOODSUNITID int32 `json:"-" xorm:"'GOODSUNITID'"` // 套保品种单位id
  636. TRADEDATE string `json:"tradedate" xorm:"'tradedate'"` // 交易日
  637. NEEDHEDGERATIO float64 `json:"needhedgeratio" xorm:"'NEEDHEDGERATIO'"` // 应套保比例
  638. NEEDARBITRAGERATIO float64 `json:"needarbitrageratio" xorm:"'NEEDARBITRAGERATIO'"` // 应套利比例
  639. BRANDNAME string `json:"brandname" xorm:"'BRANDNAME'"` // 品牌名称
  640. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货商品代码
  641. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货商品名称
  642. EnumdicName string `json:"enumdicname"` // 单位名称
  643. BUYUSERNAME string `json:"buyusername"` // 采购方名称
  644. SELLUSERNAME string `json:"sellusername"` // 销售方名称
  645. CurQty float64 `json:"curqty"` // 今定价量
  646. DiffQty float64 `json:"diffqty"` // 套保品种今变动量
  647. BeginDate string `json:"-"` // 开始交易日
  648. EndDate string `json:"-"` // 结束交易日
  649. }
  650. func (r *Ermcp3ExposureContractDetail) calc() {
  651. r.CurQty = r.QTY
  652. r.DiffQty = r.QTY * r.CONVERTRATIO
  653. r.EnumdicName = mtpcache.GetEnumDicitemName(r.UNITID)
  654. r.BUYUSERNAME = mtpcache.GetUserNameByUserId(r.BUYUSERID)
  655. r.SELLUSERNAME = mtpcache.GetUserNameByUserId(r.SELLUSERID)
  656. }
  657. func (r *Ermcp3ExposureContractDetail) buildSql() string {
  658. var sqlId utils.SQLVal = "select t.middlegoodsid," +
  659. " t.deliverygoodsid," +
  660. " t.convertratio," +
  661. " s.userid," +
  662. " to_char(s.spotcontractid) spotcontractid," +
  663. " s.contractno," +
  664. " s.contracttype," +
  665. " s.biztype," +
  666. " s.buyuserid," +
  667. " s.selluserid," +
  668. " s.qty," +
  669. " s.pricedqty," +
  670. " s.wrstandardid," +
  671. " s.audittradedate tradedate," +
  672. " w.wrstandardname," +
  673. " w.wrstandardcode," +
  674. " w.unitid," +
  675. " mg.middlegoodsname," +
  676. " mg.middlegoodscode," +
  677. " mg.goodsunitid," +
  678. " mg.needhedgeratio," +
  679. " mg.needarbitrageratio," +
  680. " dg.dgfactoryitemid brandid," +
  681. " dg.dgfactoryitemvalue brandName," +
  682. " g.deliverygoodscode," +
  683. " g.deliverygoodsname" +
  684. " from erms2_wrsconvertdetail t" +
  685. " inner join ermcp_spotcontract s" +
  686. " on t.deliverygoodsid = s.deliverygoodsid" +
  687. " left join erms_middlegoods mg" +
  688. " on t.middlegoodsid = mg.middlegoodsid" +
  689. " left join wrstandard w" +
  690. " on s.wrstandardid = w.wrstandardid" +
  691. " left join dgfactoryitem dg" +
  692. " on s.spotgoodsbrandid = dg.dgfactoryitemid" +
  693. " left join deliverygoods g on s.deliverygoodsid=g.deliverygoodsid" +
  694. " where t.wrstandardid = 0" +
  695. " and s.contractstatus in (2, 3)"
  696. sqlId.AndEx("s.audittradedate", r.TRADEDATE, len(r.TRADEDATE) > 0)
  697. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  698. sqlId.Join(fmt.Sprintf(" and s.audittradedate >= '%v' and s.audittradedate <= '%v'", r.BeginDate, r.EndDate))
  699. }
  700. sqlId.And("t.middlegoodsid", r.MIDDLEGOODSID)
  701. sqlId.Join(fmt.Sprintf(" and %v in(s.userid, s.tradeuserid)", r.USERID))
  702. return sqlId.String()
  703. }
  704. // GetDataEx 获取敞口合同明细
  705. func (r *Ermcp3ExposureContractDetail) GetDataEx() (interface{}, error) {
  706. sData := make([]Ermcp3ExposureContractDetail, 0)
  707. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  708. for i := range sData {
  709. sData[i].calc()
  710. }
  711. return sData, err
  712. }
  713. // Ermcp3ExposureHedgeplanDetail 敞口套保计划明细
  714. type Ermcp3ExposureHedgeplanDetail struct {
  715. MIDDLEGOODSID int32 `json:"middlegoodsid" xorm:"'MIDDLEGOODSID'"` // 套保品种id
  716. DELIVERYGOODSID int32 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'"` // 现货商品id
  717. CONVERTRATIO float64 `json:"convertratio" xorm:"'CONVERTRATIO'"` // 折算系数(套保品种)
  718. USERID int64 `json:"userid" xorm:"'USERID'"` // 机构id
  719. HEDGEPLANID string `json:"hedgeplanid" xorm:"'HEDGEPLANID'"` // 套保计划id
  720. HEDGEPLANNO string `json:"hedgeplanno" xorm:"'HEDGEPLANNO'"` // 套保计划编号
  721. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型(期现用途,业务类型就是期现用途) 1-套保 2-套利
  722. QTY float64 `json:"qty" xorm:"'QTY'"` // 合同量
  723. PRICEDQTY float64 `json:"pricedqty" xorm:"'PRICEDQTY'"` // 已定价量
  724. WRSTANDARDID int32 `json:"wrstandardid" xorm:"'WRSTANDARDID'"` // 品类id
  725. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'WRSTANDARDNAME'"` // 品类名称
  726. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'WRSTANDARDCODE'"` // 品类代码
  727. UNITID int32 `json:"unitid" xorm:"'UNITID'"` // 品类单位id
  728. MIDDLEGOODSNAME string `json:"middlegoodsname" xorm:"'MIDDLEGOODSNAME'"` // 套保品种名称
  729. MIDDLEGOODSCODE string `json:"middlegoodscode" xorm:"'MIDDLEGOODSCODE'"` // 套保品种代码
  730. GOODSUNITID int32 `json:"-" xorm:"'GOODSUNITID'"` // 套保品种单位id
  731. TRADEDATE string `json:"tradedate" xorm:"'tradedate'"` // 交易日(登记日)
  732. NEEDHEDGERATIO float64 `json:"needhedgeratio" xorm:"'NEEDHEDGERATIO'"` // 应套保比例
  733. NEEDARBITRAGERATIO float64 `json:"needarbitrageratio" xorm:"'NEEDARBITRAGERATIO'"` // 应套利比例
  734. CONTRACTTYPE int32 `json:"contracttype" xorm:"'CONTRACTTYPE'"` // 计划类型 - 1:采购 -1:销售
  735. HEDGEPLANSTATUS int32 `json:"hedgeplanstatus" xorm:"'HEDGEPLANSTATUS'"` // 套保计划状态 - 0:未提交 1:待审核 2:执行中 3:正常完结 4:审核拒绝 5:异常完结 6:已撤回
  736. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货商品代码
  737. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货商吕名称
  738. DGUNITID int32 `json:"dgunitid" xorm:"'DGUNITID'"` // 现货商品单位id
  739. EnumdicName string `json:"enumdicname"` // 单位名称(品类)
  740. MGUNITIDNAME string `json:"mgunitidname"` // 单位名称(套保商品)
  741. DGUNITIDNAME string `json:"dgunitidname"` // 单位名称(现货商品)
  742. CurQty float64 `json:"-"` // 今定价量
  743. DiffQty float64 `json:"diffqty"` // 套保品种今变动量
  744. ChangQty float64 `json:"changqty"` // 应套保总量变化量
  745. BeginDate string `json:"-"`
  746. EndDate string `json:"-"`
  747. }
  748. func (r *Ermcp3ExposureHedgeplanDetail) calc() {
  749. r.EnumdicName = mtpcache.GetEnumDicitemName(r.UNITID)
  750. r.MGUNITIDNAME = mtpcache.GetEnumDicitemName(r.GOODSUNITID)
  751. r.DGUNITIDNAME = mtpcache.GetEnumDicitemName(r.DGUNITID)
  752. r.CurQty = r.QTY
  753. r.DiffQty = r.QTY * r.CONVERTRATIO
  754. r.ChangQty = r.QTY * r.NEEDHEDGERATIO * r.CONVERTRATIO
  755. }
  756. func (r *Ermcp3ExposureHedgeplanDetail) buildSql() string {
  757. var sqlId utils.SQLVal = "select t.middlegoodsid," +
  758. " t.deliverygoodsid," +
  759. " t.convertratio," +
  760. " s.areauserid userid," +
  761. " to_char(s.hedgeplanid) hedgeplanid," +
  762. " s.hedgeplanno," +
  763. " s.contracttype," +
  764. " s.biztype," +
  765. " s.planqty qty," +
  766. " s.wrstandardid," +
  767. " s.audittradedate tradedate," +
  768. " s.hedgeplanstatus," +
  769. " w.wrstandardname," +
  770. " w.wrstandardcode," +
  771. " w.unitid," +
  772. " g.deliverygoodscode," +
  773. " g.deliverygoodsname," +
  774. " g.goodsunitid," +
  775. " mg.middlegoodsname," +
  776. " mg.middlegoodscode," +
  777. " mg.goodsunitid," +
  778. " mg.needhedgeratio," +
  779. " mg.needarbitrageratio" +
  780. " from erms2_wrsconvertdetail t" +
  781. " inner join ermcp_hedgeplan s" +
  782. " on t.deliverygoodsid = s.deliverygoodsid" +
  783. " left join erms_middlegoods mg" +
  784. " on t.middlegoodsid = mg.middlegoodsid" +
  785. " left join wrstandard w" +
  786. " on s.wrstandardid = w.wrstandardid" +
  787. " left join deliverygoods g on s.deliverygoodsid=g.deliverygoodsid" +
  788. " where t.wrstandardid = 0" +
  789. " and s.hedgeplanstatus in (2, 3)"
  790. sqlId.AndEx("s.audittradedate", r.TRADEDATE, len(r.TRADEDATE) > 0)
  791. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  792. sqlId.Join(fmt.Sprintf(" and s.audittradedate >= '%v' and s.audittradedate <= '%v'", r.BeginDate, r.EndDate))
  793. }
  794. sqlId.And("t.middlegoodsid", r.MIDDLEGOODSID)
  795. sqlId.Join(fmt.Sprintf(" and %v in(s.areauserid, s.tradeuserid)", r.USERID))
  796. return sqlId.String()
  797. }
  798. // GetDataEx 获取敞口套保计划明细
  799. func (r *Ermcp3ExposureHedgeplanDetail) GetDataEx() (interface{}, error) {
  800. sData := make([]Ermcp3ExposureHedgeplanDetail, 0)
  801. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  802. for i := range sData {
  803. sData[i].calc()
  804. }
  805. return sData, err
  806. }
  807. // Ermcp3AreaSpotPLReport 现货报表(日/月/周/季/年)
  808. type Ermcp3AreaSpotPLReport struct {
  809. RECKONDATE string `json:"reckondate" xorm:"RECKONDATE"` // 日照时期(yyyyMMdd)
  810. CYCLETIME string `json:"cycletime" xorm:"'CYCLETIME'"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  811. CYCLETYPE int32 `json:"cycletype" xorm:"'CYCLETYPE'"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  812. AREAUSERID int64 `json:"areauserid" xorm:"AREAUSERID"` // 所属机构\交易用户ID
  813. ACCOUNTID int64 `json:"accountid" xorm:"ACCOUNTID"` // 期货账户ID (作废, 默认为0)
  814. WRFACTORTYPEID int64 `json:"wrfactortypeid" xorm:"WRFACTORTYPEID"` // 仓单要素类型ID(212+Unix秒时间戳(10位)+xxxxxx)
  815. CURRENCYID int32 `json:"currencyid" xorm:"CURRENCYID"` // 结算币种ID【原值】
  816. BIZTYPE int32 `json:"biztype" xorm:"BIZTYPE"` // 业务类型 - 1:套保 2:套利
  817. DELIVERYGOODSID int64 `json:"deliverygoodsid" xorm:"DELIVERYGOODSID"` // 现货品种ID
  818. WRSTANDARDID int64 `json:"wrstandardid" xorm:"WRSTANDARDID"` // 现货品类ID
  819. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"SPOTGOODSBRANDID"` // 现货品牌ID
  820. ORIBUYQTY float64 `json:"oribuyqty" xorm:"ORIBUYQTY"` // 期初采购总量
  821. ORIBUYAMOUNT float64 `json:"oribuyamount" xorm:"ORIBUYAMOUNT"` // 期初采购总额
  822. ORISELLQTY float64 `json:"orisellqty" xorm:"ORISELLQTY"` // 期初销售总量
  823. ORISELLAMOUNT float64 `json:"orisellamount" xorm:"ORISELLAMOUNT"` // 期初销售总额
  824. ORIQTY float64 `json:"oriqty" xorm:"ORIQTY"` // 期初量
  825. ORIAVERAGEPRICE float64 `json:"oriaverageprice" xorm:"ORIAVERAGEPRICE"` // 期初均价
  826. ORIAMOUNT float64 `json:"oriamount" xorm:"ORIAMOUNT"` // 期初额
  827. TODAYBUYQTY float64 `json:"todaybuyqty" xorm:"TODAYBUYQTY"` // 今日采购量(今采购量)
  828. TODAYBUYAMOUNT float64 `json:"todaybuyamount" xorm:"TODAYBUYAMOUNT"` // 今日采购额(今采购额)
  829. TODAYBUYAVERAGEPRICE float64 `json:"todaybuyaverageprice" xorm:"TODAYBUYAVERAGEPRICE"` // 今日采购均价
  830. TODAYSELLQTY float64 `json:"todaysellqty" xorm:"TODAYSELLQTY"` // 今日销售量(今销售量)
  831. TODAYSELLAMOUNT float64 `json:"todaysellamount" xorm:"TODAYSELLAMOUNT"` // 今日销售额(今销售额)
  832. TODAYSELLAVERAGEPRICE float64 `json:"todaysellaverageprice" xorm:"TODAYSELLAVERAGEPRICE"` // 今日销售均价
  833. CURBUYQTY float64 `json:"curbuyqty" xorm:"CURBUYQTY"` // 期末采购总量
  834. CURBUYAMOUNT float64 `json:"curbuyamount" xorm:"CURBUYAMOUNT"` // 期末采购总额
  835. CURSELLQTY float64 `json:"cursellqty" xorm:"CURSELLQTY"` // 期末销售总量
  836. CURSELLAMOUNT float64 `json:"cursellamount" xorm:"CURSELLAMOUNT"` // 期末销售总额
  837. CURQTY float64 `json:"curqty" xorm:"CURQTY"` // 期末量
  838. CURAVERAGEPRICE float64 `json:"curaverageprice" xorm:"CURAVERAGEPRICE"` // 期末均价
  839. CURAMOUNT float64 `json:"curamount" xorm:"CURAMOUNT"` // 期末额
  840. CURSPOTPRICE float64 `json:"curspotprice" xorm:"CURSPOTPRICE"` // 参考市价(最新价)
  841. CURMARKETVALUE float64 `json:"curmarketvalue" xorm:"CURMARKETVALUE"` // 参考市值(期末市值)
  842. ACTUALPL float64 `json:"actualpl" xorm:"ACTUALPL"` // 现货损益
  843. FLOATPL float64 `json:"floatpl" xorm:"FLOATPL"` // 浮动损益
  844. UPDATETIME string `json:"updatetime" xorm:"UPDATETIME"` // 更新时间
  845. TODAYINQTY float64 `json:"todayinqty" xorm:"TODAYINQTY"` // 今日入库量(今入库量)
  846. TODAYOUTQTY float64 `json:"todayoutqty" xorm:"TODAYOUTQTY"` // 今日出库量(今出库量)
  847. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货商品代码
  848. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货商品名称
  849. GOODSUNITID int32 `json:"goodsunitid" xorm:"'GOODSUNITID'"` // 现货商品单位id
  850. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'WRSTANDARDCODE'"` // 品类代码
  851. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'WRSTANDARDNAME'"` // 品类名称
  852. UNITID int32 `json:"unitid" xorm:"'UNITID'"` // 品类单位id
  853. BRANDNAME string `json:"brandname" xorm:"'BRANDNAME'"` // 品牌名称
  854. EnumdicName string `json:"enumdicname"` // 现货商品单位名称
  855. UNITIDNAME string `json:"unitidname"` // 品类单位名称
  856. ACCOUNTNAME string `json:"accountname"` // 机构名称
  857. CURRENCYNAME string `json:"currencyname"` // 币种名称
  858. QueryType int32 `json:"-"` // 查询类型 1-报表 2-报表明细
  859. BeginDate string `json:"begindate"` // 开始交易日
  860. EndDate string `json:"enddate"` // 结束交易日
  861. }
  862. func (r *Ermcp3AreaSpotPLReport) calc() {
  863. r.EnumdicName = mtpcache.GetEnumDicitemName(r.GOODSUNITID)
  864. r.UNITIDNAME = mtpcache.GetEnumDicitemName(r.UNITID)
  865. r.ACCOUNTNAME = mtpcache.GetUserNameByUserId(r.AREAUSERID)
  866. r.CURRENCYNAME = mtpcache.GetCurrencyName(r.CURRENCYID)
  867. }
  868. func (r *Ermcp3AreaSpotPLReport) buildSql() string {
  869. // 日报表
  870. if r.QueryType == 1 && r.CYCLETYPE == 0 {
  871. return r.buildSqlDay()
  872. }
  873. // 日报表明细
  874. if r.QueryType == 2 && r.CYCLETYPE == 0 {
  875. return r.buildSqlDayDetail()
  876. }
  877. return r.buildSqlCycle()
  878. }
  879. // buildSqlDay 现货日报表查询语句
  880. func (r *Ermcp3AreaSpotPLReport) buildSqlDay() string {
  881. var sqlId utils.SQLVal = "select a.*," +
  882. " g.deliverygoodscode," +
  883. " g.deliverygoodsname," +
  884. " g.goodsunitid" +
  885. " from (SELECT t.RECKONDATE," +
  886. " t.AREAUSERID," +
  887. " t.CURRENCYID," +
  888. " t.DELIVERYGOODSID," +
  889. " sum(t.ORIBUYQTY) ORIBUYQTY," +
  890. " sum(t.ORIBUYAMOUNT) ORIBUYAMOUNT," +
  891. " sum(t.ORISELLQTY) ORISELLQTY," +
  892. " sum(t.ORISELLAMOUNT) ORISELLAMOUNT," +
  893. " sum(t.ORIQTY) ORIQTY," +
  894. " sum(t.ORIAVERAGEPRICE) ORIAVERAGEPRICE," +
  895. " sum(t.ORIAMOUNT) ORIAMOUNT," +
  896. " sum(t.TODAYBUYQTY) TODAYBUYQTY," +
  897. " sum(t.TODAYBUYAMOUNT) TODAYBUYAMOUNT," +
  898. " sum(t.TODAYBUYAVERAGEPRICE) TODAYBUYAVERAGEPRICE," +
  899. " sum(t.TODAYSELLQTY) TODAYSELLQTY," +
  900. " sum(t.TODAYSELLAMOUNT) TODAYSELLAMOUNT," +
  901. " sum(t.TODAYSELLAVERAGEPRICE) TODAYSELLAVERAGEPRICE," +
  902. " sum(t.CURBUYQTY) CURBUYQTY," +
  903. " sum(t.CURBUYAMOUNT) CURBUYAMOUNT," +
  904. " sum(t.CURSELLQTY) CURSELLQTY," +
  905. " sum(t.CURSELLAMOUNT) CURSELLAMOUNT," +
  906. " sum(t.CURQTY) CURQTY," +
  907. " sum(t.CURAVERAGEPRICE) CURAVERAGEPRICE," +
  908. " sum(t.CURAMOUNT) CURAMOUNT," +
  909. " sum(t.CURSPOTPRICE) CURSPOTPRICE," +
  910. " sum(t.CURMARKETVALUE) CURMARKETVALUE," +
  911. " sum(t.ACTUALPL) ACTUALPL," +
  912. " sum(t.FLOATPL) FLOATPL," +
  913. " sum(t.TODAYINQTY) TODAYINQTY," +
  914. " sum(t.TODAYOUTQTY) TODAYOUTQTY" +
  915. " FROM RECKON_ERMCP_AREASPOTPL t" +
  916. " WHERE 1=1 %v" +
  917. " GROUP BY t.RECKONDATE," +
  918. " t.AREAUSERID," +
  919. " t.CURRENCYID," +
  920. " t.DELIVERYGOODSID) a" +
  921. " LEFT JOIN DELIVERYGOODS g" +
  922. " on a.deliverygoodsid = g.deliverygoodsid"
  923. var sqlParam utils.SQLVal
  924. sqlParam.And("t.AREAUSERID", r.AREAUSERID)
  925. if r.QueryType == 1 {
  926. sqlParam.And("t.RECKONDATE", r.RECKONDATE)
  927. } else if r.QueryType == 2 {
  928. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  929. }
  930. sqlId.FormatParam(sqlParam.String())
  931. return sqlId.String()
  932. }
  933. func (r *Ermcp3AreaSpotPLReport) buildSqlDayDetail() string {
  934. var sqlId utils.SQLVal = "select a.*," +
  935. " g.deliverygoodscode," +
  936. " g.deliverygoodsname," +
  937. " g.goodsunitid," +
  938. " w.wrstandardcode," +
  939. " w.wrstandardname," +
  940. " w.unitid," +
  941. " dg.dgfactoryitemvalue brandName" +
  942. " from (SELECT t.RECKONDATE," +
  943. " t.AREAUSERID," +
  944. " t.CURRENCYID," +
  945. " t.DELIVERYGOODSID," +
  946. " t.WRSTANDARDID," +
  947. " t.SPOTGOODSBRANDID," +
  948. " sum(t.ORIBUYQTY) ORIBUYQTY," +
  949. " sum(t.ORIBUYAMOUNT) ORIBUYAMOUNT," +
  950. " sum(t.ORISELLQTY) ORISELLQTY," +
  951. " sum(t.ORISELLAMOUNT) ORISELLAMOUNT," +
  952. " sum(t.ORIQTY) ORIQTY," +
  953. " sum(t.ORIAVERAGEPRICE) ORIAVERAGEPRICE," +
  954. " sum(t.ORIAMOUNT) ORIAMOUNT," +
  955. " sum(t.TODAYBUYQTY) TODAYBUYQTY," +
  956. " sum(t.TODAYBUYAMOUNT) TODAYBUYAMOUNT," +
  957. " sum(t.TODAYBUYAVERAGEPRICE) TODAYBUYAVERAGEPRICE," +
  958. " sum(t.TODAYSELLQTY) TODAYSELLQTY," +
  959. " sum(t.TODAYSELLAMOUNT) TODAYSELLAMOUNT," +
  960. " sum(t.TODAYSELLAVERAGEPRICE) TODAYSELLAVERAGEPRICE," +
  961. " sum(t.CURBUYQTY) CURBUYQTY," +
  962. " sum(t.CURBUYAMOUNT) CURBUYAMOUNT," +
  963. " sum(t.CURSELLQTY) CURSELLQTY," +
  964. " sum(t.CURSELLAMOUNT) CURSELLAMOUNT," +
  965. " sum(t.CURQTY) CURQTY," +
  966. " sum(t.CURAVERAGEPRICE) CURAVERAGEPRICE," +
  967. " sum(t.CURAMOUNT) CURAMOUNT," +
  968. " sum(t.CURSPOTPRICE) CURSPOTPRICE," +
  969. " sum(t.CURMARKETVALUE) CURMARKETVALUE," +
  970. " sum(t.ACTUALPL) ACTUALPL," +
  971. " sum(t.FLOATPL) FLOATPL," +
  972. " sum(t.TODAYINQTY) TODAYINQTY," +
  973. " sum(t.TODAYOUTQTY) TODAYOUTQTY" +
  974. " FROM RECKON_ERMCP_AREASPOTPL t" +
  975. " WHERE 1 = 1 %v" +
  976. " GROUP BY t.RECKONDATE," +
  977. " t.AREAUSERID," +
  978. " t.CURRENCYID," +
  979. " t.DELIVERYGOODSID," +
  980. " t.WRSTANDARDID," +
  981. " t.SPOTGOODSBRANDID) a" +
  982. " LEFT JOIN DELIVERYGOODS g" +
  983. " on a.deliverygoodsid = g.deliverygoodsid" +
  984. " LEFT JOIN WRSTANDARD w" +
  985. " on a.wrstandardid = w.wrstandardid" +
  986. " LEFT JOIN DGFACTORYITEM dg" +
  987. " on a.spotgoodsbrandid = dg.dgfactoryitemid"
  988. var sqlParam utils.SQLVal
  989. sqlParam.And("t.AREAUSERID", r.AREAUSERID)
  990. sqlParam.AndEx("t.RECKONDATE", r.RECKONDATE, len(r.RECKONDATE) > 0)
  991. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  992. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  993. }
  994. sqlParam.And("t.CURRENCYID", r.CURRENCYID)
  995. sqlParam.And("t.DELIVERYGOODSID", r.DELIVERYGOODSID)
  996. sqlId.FormatParam(sqlParam.String())
  997. return sqlId.String()
  998. }
  999. // buildSqlCycle 周期报表查询语句
  1000. func (r *Ermcp3AreaSpotPLReport) buildSqlCycle() string {
  1001. var sqlId utils.SQLVal = "select a.*," +
  1002. " g.deliverygoodscode," +
  1003. " g.deliverygoodsname," +
  1004. " g.goodsunitid" +
  1005. " from (SELECT t.cycletype," +
  1006. " t.cycletime," +
  1007. " t.AREAUSERID," +
  1008. " t.CURRENCYID," +
  1009. " t.DELIVERYGOODSID," +
  1010. " sum(t.ORIBUYQTY) ORIBUYQTY," +
  1011. " sum(t.ORIBUYAMOUNT) ORIBUYAMOUNT," +
  1012. " sum(t.ORISELLQTY) ORISELLQTY," +
  1013. " sum(t.ORISELLAMOUNT) ORISELLAMOUNT," +
  1014. " sum(t.ORIQTY) ORIQTY," +
  1015. " sum(t.ORIAVERAGEPRICE) ORIAVERAGEPRICE," +
  1016. " sum(t.ORIAMOUNT) ORIAMOUNT," +
  1017. " sum(t.TODAYBUYQTY) TODAYBUYQTY," +
  1018. " sum(t.TODAYBUYAMOUNT) TODAYBUYAMOUNT," +
  1019. " sum(t.TODAYBUYAVERAGEPRICE) TODAYBUYAVERAGEPRICE," +
  1020. " sum(t.TODAYSELLQTY) TODAYSELLQTY," +
  1021. " sum(t.TODAYSELLAMOUNT) TODAYSELLAMOUNT," +
  1022. " sum(t.TODAYSELLAVERAGEPRICE) TODAYSELLAVERAGEPRICE," +
  1023. " sum(t.CURBUYQTY) CURBUYQTY," +
  1024. " sum(t.CURBUYAMOUNT) CURBUYAMOUNT," +
  1025. " sum(t.CURSELLQTY) CURSELLQTY," +
  1026. " sum(t.CURSELLAMOUNT) CURSELLAMOUNT," +
  1027. " sum(t.CURQTY) CURQTY," +
  1028. " sum(t.CURAVERAGEPRICE) CURAVERAGEPRICE," +
  1029. " sum(t.CURAMOUNT) CURAMOUNT," +
  1030. " sum(t.CURSPOTPRICE) CURSPOTPRICE," +
  1031. " sum(t.CURMARKETVALUE) CURMARKETVALUE," +
  1032. " sum(t.ACTUALPL) ACTUALPL," +
  1033. " sum(t.FLOATPL) FLOATPL," +
  1034. " sum(t.TODAYINQTY) TODAYINQTY," +
  1035. " sum(t.TODAYOUTQTY) TODAYOUTQTY" +
  1036. " FROM REPORT_ERMCP_AREASPOTPL t" +
  1037. " WHERE 1=1 %v" +
  1038. " GROUP BY t.AREAUSERID," +
  1039. " t.cycletype," +
  1040. " t.cycletime," +
  1041. " t.CURRENCYID," +
  1042. " t.DELIVERYGOODSID) a" +
  1043. " LEFT JOIN DELIVERYGOODS g" +
  1044. " on a.deliverygoodsid = g.deliverygoodsid"
  1045. var sqlParam utils.SQLVal
  1046. sqlParam.And("t.AREAUSERID", r.AREAUSERID)
  1047. sqlParam.And("t.Cycletype", r.CYCLETYPE)
  1048. sqlParam.And("t.CYCLETIME", r.CYCLETIME)
  1049. sqlId.FormatParam(sqlParam.String())
  1050. return sqlId.String()
  1051. }
  1052. // GetDataEx 获取现货报表(日/月/周/季/年)
  1053. func (r *Ermcp3AreaSpotPLReport) GetDataEx() (interface{}, error) {
  1054. sData := make([]Ermcp3AreaSpotPLReport, 0)
  1055. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  1056. for i := range sData {
  1057. sData[i].calc()
  1058. sData[i].BeginDate = r.BeginDate
  1059. sData[i].EndDate = r.EndDate
  1060. }
  1061. return sData, err
  1062. }
  1063. // Ermcp3FinanceReport 财务报表
  1064. type Ermcp3FinanceReport struct {
  1065. RECKONDATE string `json:"reckondate" xorm:"RECKONDATE"` // 日照时期(yyyyMMdd)
  1066. CYCLETIME string `json:"cycletime" xorm:"CYCLETIME"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  1067. CYCLETYPE int32 `json:"cycletype" xorm:"CYCLETYPE"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  1068. SELLPREINVOICEDAMOUNT float64 `json:"sellpreinvoicedamount" xorm:"SELLPREINVOICEDAMOUNT"` // 销售预开票额(预开票额)
  1069. SELLUNINVOICEDAMOUNT float64 `json:"selluninvoicedamount" xorm:"SELLUNINVOICEDAMOUNT"` // 销售应开票额(应开票额)
  1070. TODAYRECEIVESUM float64 `json:"todayreceivesum" xorm:"TODAYRECEIVESUM"` // 今收款合计
  1071. TODAYPAYSUM float64 `json:"todaypaysum" xorm:"TODAYPAYSUM"` // 今付款合计
  1072. UPDATETIME string `json:"updatetime" xorm:"UPDATETIME"` // 更新时间
  1073. AREAUSERID int64 `json:"areauserid" xorm:"AREAUSERID"` // 所属机构\交易用户ID
  1074. CURRENCYID int32 `json:"currencyid" xorm:"CURRENCYID"` // 结算币种ID
  1075. BIZTYPE int32 `json:"biztype" xorm:"BIZTYPE"` // 业务类型 - 1:套保 2:套利
  1076. BUYTODAYSETTLEAMOUNT float64 `json:"buytodaysettleamount" xorm:"BUYTODAYSETTLEAMOUNT"` // 采购今付款额(今付货款额)
  1077. SELLTODAYSETTLEAMOUNT float64 `json:"selltodaysettleamount" xorm:"SELLTODAYSETTLEAMOUNT"` // 销售今收款额(今收货款额)
  1078. BUYTODAYREFUNDAMOUNT float64 `json:"buytodayrefundamount" xorm:"BUYTODAYREFUNDAMOUNT"` // 采购今收退款额(今收退款额)
  1079. SELLTODAYREFUNDAMOUNT float64 `json:"selltodayrefundamount" xorm:"SELLTODAYREFUNDAMOUNT"` // 销售今付退款额(今付退款额)
  1080. SELLTODAYINVOICEAMOUNT float64 `json:"selltodayinvoiceamount" xorm:"SELLTODAYINVOICEAMOUNT"` // 销售今开票额(今开票额)
  1081. BUYTODAYINVOICEAMOUNT float64 `json:"buytodayinvoiceamount" xorm:"BUYTODAYINVOICEAMOUNT"` // 采购今收票额(今收票额)
  1082. BUYPREPAIDAMOUNT float64 `json:"buyprepaidamount" xorm:"BUYPREPAIDAMOUNT"` // 采购预付款额(预付货款额)
  1083. BUYUNPAIDAMOUNT float64 `json:"buyunpaidamount" xorm:"BUYUNPAIDAMOUNT"` // 采购应付款额(应付货款额)
  1084. BUYPREINVOICEDAMOUNT float64 `json:"buypreinvoicedamount" xorm:"BUYPREINVOICEDAMOUNT"` // 采购预收票额(预收票额)
  1085. BUYUNINVOICEDAMOUNT float64 `json:"buyuninvoicedamount" xorm:"BUYUNINVOICEDAMOUNT"` // 采购应收票额(应收票额)
  1086. SELLPREPAIDAMOUNT float64 `json:"sellprepaidamount" xorm:"SELLPREPAIDAMOUNT"` // 销售预收款额(预收货款额)
  1087. SELLUNPAIDAMOUNT float64 `json:"sellunpaidamount" xorm:"SELLUNPAIDAMOUNT"` // 销售应收款额(应收货款额)
  1088. WRFACTORTYPEID int64 `json:"wrfactortypeid" xorm:"WRFACTORTYPEID"` // 仓单要素类型ID(212+Unix秒时间戳(10位)+xxxxxx)
  1089. DELIVERYGOODSID int64 `json:"deliverygoodsid" xorm:"DELIVERYGOODSID"` // 现货品种ID
  1090. WRSTANDARDID int64 `json:"wrstandardid" xorm:"WRSTANDARDID"` // 现货商品ID
  1091. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"SPOTGOODSBRANDID"` // 现货品牌ID
  1092. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货品种代码
  1093. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货品种名称
  1094. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'WRSTANDARDCODE'"` // 品类代码
  1095. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'WRSTANDARDNAME'"` // 品类名称
  1096. BRANDNAME string `json:"brandname" xorm:"'BRANDNAME'"` // 品牌名称
  1097. ACCOUNTNAME string `json:"accountname"` // 机构名称
  1098. CURRENCYNAME string `json:"currencyname"` // 币种名称
  1099. QueryType int32 `json:"-"` // 查询类型 1-报表 2-报表明细
  1100. BeginDate string `json:"begindate"` // 开始交易日
  1101. EndDate string `json:"enddate"` // 结束交易日
  1102. SumFields string `json:"-"` // 维度字段
  1103. }
  1104. func (r *Ermcp3FinanceReport) calc() {
  1105. r.CURRENCYNAME = mtpcache.GetCurrencyName(r.CURRENCYID)
  1106. r.ACCOUNTNAME = mtpcache.GetUserNameByUserId(r.AREAUSERID)
  1107. f := func(v *float64) {
  1108. if *v < 0 {
  1109. *v = 0
  1110. }
  1111. }
  1112. f(&r.BUYPREPAIDAMOUNT)
  1113. f(&r.SELLPREINVOICEDAMOUNT)
  1114. f(&r.BUYUNINVOICEDAMOUNT)
  1115. f(&r.SELLPREPAIDAMOUNT)
  1116. }
  1117. // getSumField 获取汇总维度字段
  1118. func (r *Ermcp3FinanceReport) getSumField() (fields []string) {
  1119. fields = append(fields, "areauserid")
  1120. fields = append(fields, "currencyid")
  1121. if r.CYCLETYPE == 0 {
  1122. // 日报表
  1123. fields = append(fields, "reckondate")
  1124. } else {
  1125. // 周期报表
  1126. fields = append(fields, "cycletype")
  1127. fields = append(fields, "cycletime")
  1128. }
  1129. baseField := map[string]string{
  1130. "1": "deliverygoodsid",
  1131. "2": "wrstandardid",
  1132. "3": "spotgoodsbrandid",
  1133. }
  1134. param := []string{}
  1135. if len(r.SumFields) > 0 {
  1136. param = strings.Split(r.SumFields, ",")
  1137. }
  1138. for k, v := range baseField {
  1139. for _, p := range param {
  1140. if k == p {
  1141. fields = append(fields, v)
  1142. }
  1143. }
  1144. }
  1145. return
  1146. }
  1147. func (r *Ermcp3FinanceReport) getExFieldInfo() (strFiled string, strleftJoin string) {
  1148. if len(r.SumFields) > 0 {
  1149. param := strings.Split(r.SumFields, ",")
  1150. fHas := func(v string) bool {
  1151. for i := range param {
  1152. if param[i] == v {
  1153. return true
  1154. }
  1155. }
  1156. return false
  1157. }
  1158. if fHas("1") {
  1159. if len(strFiled) > 0 {
  1160. strFiled += ","
  1161. }
  1162. strFiled += "g.deliverygoodscode, g.deliverygoodsname, g.goodsunitid"
  1163. strleftJoin += " LEFT JOIN deliverygoods g on a.deliverygoodsid = g.deliverygoodsid"
  1164. }
  1165. if fHas("2") {
  1166. if len(strFiled) > 0 {
  1167. strFiled += ","
  1168. }
  1169. strFiled += "w.wrstandardname, w.wrstandardcode, w.unitid"
  1170. strleftJoin += " LEFT JOIN WRSTANDARD w on a.wrstandardid = w.wrstandardid"
  1171. }
  1172. if fHas("3") {
  1173. if len(strFiled) > 0 {
  1174. strFiled += ","
  1175. }
  1176. strFiled += "gb.dgfactoryitemvalue brandname"
  1177. strleftJoin += " LEFT JOIN dgfactoryitem gb on a.spotgoodsbrandid = gb.dgfactoryitemid"
  1178. }
  1179. }
  1180. return
  1181. }
  1182. func (r *Ermcp3FinanceReport) buildSql() string {
  1183. fields := r.getSumField()
  1184. if r.CYCLETYPE == 0 {
  1185. // 查日照报
  1186. return r.buildSqlReckon(fields)
  1187. } else {
  1188. // 查报表表
  1189. return r.buildSqlReport(fields)
  1190. }
  1191. }
  1192. func (r *Ermcp3FinanceReport) buildSqlReckon(fields []string) string {
  1193. var sqlId, sqlParam utils.SQLVal
  1194. var strFileds string
  1195. for _, v := range fields {
  1196. if len(strFileds) > 0 {
  1197. strFileds += ","
  1198. }
  1199. strFileds += "t." + v
  1200. }
  1201. sqlParam.And("t.AREAUSERID", r.AREAUSERID)
  1202. sqlParam.AndEx("t.RECKONDATE", r.RECKONDATE, len(r.RECKONDATE) > 0)
  1203. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  1204. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1205. }
  1206. sqlParam.AndEx("t.CURRENCYID", r.CURRENCYID, r.CURRENCYID > 0)
  1207. exFileds, strleftJoin := r.getExFieldInfo()
  1208. if len(exFileds) > 0 {
  1209. // 有左联查额外信息(RECKON_ERMCP_AFINANCESUB明细表, 注意是不同的表)
  1210. sqlId = "select a.*, %v" +
  1211. " from (SELECT %v," +
  1212. " sum(t.BUYTODAYSETTLEAMOUNT) BUYTODAYSETTLEAMOUNT," +
  1213. " sum(t.BUYTODAYREFUNDAMOUNT) BUYTODAYREFUNDAMOUNT," +
  1214. " sum(t.BUYPREPAIDAMOUNT) BUYPREPAIDAMOUNT," +
  1215. " sum(t.BUYUNPAIDAMOUNT) BUYUNPAIDAMOUNT," +
  1216. " sum(t.BUYTODAYINVOICEAMOUNT) BUYTODAYINVOICEAMOUNT," +
  1217. " sum(t.BUYPREINVOICEDAMOUNT) BUYPREINVOICEDAMOUNT," +
  1218. " sum(t.BUYUNINVOICEDAMOUNT) BUYUNINVOICEDAMOUNT," +
  1219. " sum(t.SELLTODAYSETTLEAMOUNT) SELLTODAYSETTLEAMOUNT," +
  1220. " sum(t.SELLTODAYREFUNDAMOUNT) SELLTODAYREFUNDAMOUNT," +
  1221. " sum(t.SELLPREPAIDAMOUNT) SELLPREPAIDAMOUNT," +
  1222. " sum(t.SELLUNPAIDAMOUNT) SELLUNPAIDAMOUNT," +
  1223. " sum(t.SELLTODAYINVOICEAMOUNT) SELLTODAYINVOICEAMOUNT," +
  1224. " sum(t.SELLPREINVOICEDAMOUNT) SELLPREINVOICEDAMOUNT," +
  1225. " sum(t.SELLUNINVOICEDAMOUNT) SELLUNINVOICEDAMOUNT," +
  1226. " sum(t.TODAYRECEIVESUM) TODAYRECEIVESUM," +
  1227. " sum(t.TODAYPAYSUM) TODAYPAYSUM" +
  1228. " FROM RECKON_ERMCP_AFINANCESUB t" +
  1229. " WHERE 1 = 1 %v" +
  1230. " GROUP BY %v) a %v"
  1231. sqlId.FormatParam(exFileds, strFileds, sqlParam.String(), strFileds, strleftJoin)
  1232. } else {
  1233. sqlId = "SELECT %v," +
  1234. " sum(t.BUYTODAYSETTLEAMOUNT) BUYTODAYSETTLEAMOUNT," +
  1235. " sum(t.BUYTODAYREFUNDAMOUNT) BUYTODAYREFUNDAMOUNT," +
  1236. " sum(t.BUYPREPAIDAMOUNT) BUYPREPAIDAMOUNT," +
  1237. " sum(t.BUYUNPAIDAMOUNT) BUYUNPAIDAMOUNT," +
  1238. " sum(t.BUYTODAYINVOICEAMOUNT) BUYTODAYINVOICEAMOUNT," +
  1239. " sum(t.BUYPREINVOICEDAMOUNT) BUYPREINVOICEDAMOUNT," +
  1240. " sum(t.BUYUNINVOICEDAMOUNT) BUYUNINVOICEDAMOUNT," +
  1241. " sum(t.SELLTODAYSETTLEAMOUNT) SELLTODAYSETTLEAMOUNT," +
  1242. " sum(t.SELLTODAYREFUNDAMOUNT) SELLTODAYREFUNDAMOUNT," +
  1243. " sum(t.SELLPREPAIDAMOUNT) SELLPREPAIDAMOUNT," +
  1244. " sum(t.SELLUNPAIDAMOUNT) SELLUNPAIDAMOUNT," +
  1245. " sum(t.SELLTODAYINVOICEAMOUNT) SELLTODAYINVOICEAMOUNT," +
  1246. " sum(t.SELLPREINVOICEDAMOUNT) SELLPREINVOICEDAMOUNT," +
  1247. " sum(t.SELLUNINVOICEDAMOUNT) SELLUNINVOICEDAMOUNT," +
  1248. " sum(t.TODAYRECEIVESUM) TODAYRECEIVESUM," +
  1249. " sum(t.TODAYPAYSUM) TODAYPAYSUM" +
  1250. " FROM RECKON_ERMCP_AREAFINANCE t" +
  1251. " WHERE 1 = 1 %v" +
  1252. " GROUP BY %v"
  1253. sqlId.FormatParam(strFileds, sqlParam.String(), strFileds)
  1254. }
  1255. return sqlId.String()
  1256. }
  1257. func (r *Ermcp3FinanceReport) buildSqlReport(fields []string) string {
  1258. var sqlId, sqlParam utils.SQLVal
  1259. var strFileds string
  1260. for _, v := range fields {
  1261. if len(strFileds) > 0 {
  1262. strFileds += ","
  1263. }
  1264. strFileds += "t." + v
  1265. }
  1266. sqlParam.And("t.AREAUSERID", r.AREAUSERID)
  1267. sqlParam.And("t.CYCLETYPE", r.CYCLETYPE)
  1268. sqlParam.And("t.CYCLETIME", r.CYCLETIME)
  1269. sqlParam.AndEx("t.CURRENCYID", r.CURRENCYID, r.CURRENCYID > 0)
  1270. exFileds, strleftJoin := r.getExFieldInfo()
  1271. if len(exFileds) > 0 {
  1272. // 有左联查额外信息(REPORT_ERMCP_AFINANCESUB注意表名不同)
  1273. sqlId = "select a.*, %v" +
  1274. " from (SELECT %v," +
  1275. " sum(t.BUYTODAYSETTLEAMOUNT) BUYTODAYSETTLEAMOUNT," +
  1276. " sum(t.BUYTODAYREFUNDAMOUNT) BUYTODAYREFUNDAMOUNT," +
  1277. " sum(t.BUYPREPAIDAMOUNT) BUYPREPAIDAMOUNT," +
  1278. " sum(t.BUYUNPAIDAMOUNT) BUYUNPAIDAMOUNT," +
  1279. " sum(t.BUYTODAYINVOICEAMOUNT) BUYTODAYINVOICEAMOUNT," +
  1280. " sum(t.BUYPREINVOICEDAMOUNT) BUYPREINVOICEDAMOUNT," +
  1281. " sum(t.BUYUNINVOICEDAMOUNT) BUYUNINVOICEDAMOUNT," +
  1282. " sum(t.SELLTODAYSETTLEAMOUNT) SELLTODAYSETTLEAMOUNT," +
  1283. " sum(t.SELLTODAYREFUNDAMOUNT) SELLTODAYREFUNDAMOUNT," +
  1284. " sum(t.SELLPREPAIDAMOUNT) SELLPREPAIDAMOUNT," +
  1285. " sum(t.SELLUNPAIDAMOUNT) SELLUNPAIDAMOUNT," +
  1286. " sum(t.SELLTODAYINVOICEAMOUNT) SELLTODAYINVOICEAMOUNT," +
  1287. " sum(t.SELLPREINVOICEDAMOUNT) SELLPREINVOICEDAMOUNT," +
  1288. " sum(t.SELLUNINVOICEDAMOUNT) SELLUNINVOICEDAMOUNT," +
  1289. " sum(t.TODAYRECEIVESUM) TODAYRECEIVESUM," +
  1290. " sum(t.TODAYPAYSUM) TODAYPAYSUM" +
  1291. " FROM REPORT_ERMCP_AFINANCESUB t" +
  1292. " WHERE 1 = 1 %v" +
  1293. " GROUP BY %v) a %v"
  1294. sqlId.FormatParam(exFileds, strFileds, sqlParam.String(), strFileds, strleftJoin)
  1295. } else {
  1296. sqlId = "SELECT %v," +
  1297. " sum(t.BUYTODAYSETTLEAMOUNT) BUYTODAYSETTLEAMOUNT," +
  1298. " sum(t.BUYTODAYREFUNDAMOUNT) BUYTODAYREFUNDAMOUNT," +
  1299. " sum(t.BUYPREPAIDAMOUNT) BUYPREPAIDAMOUNT," +
  1300. " sum(t.BUYUNPAIDAMOUNT) BUYUNPAIDAMOUNT," +
  1301. " sum(t.BUYTODAYINVOICEAMOUNT) BUYTODAYINVOICEAMOUNT," +
  1302. " sum(t.BUYPREINVOICEDAMOUNT) BUYPREINVOICEDAMOUNT," +
  1303. " sum(t.BUYUNINVOICEDAMOUNT) BUYUNINVOICEDAMOUNT," +
  1304. " sum(t.SELLTODAYSETTLEAMOUNT) SELLTODAYSETTLEAMOUNT," +
  1305. " sum(t.SELLTODAYREFUNDAMOUNT) SELLTODAYREFUNDAMOUNT," +
  1306. " sum(t.SELLPREPAIDAMOUNT) SELLPREPAIDAMOUNT," +
  1307. " sum(t.SELLUNPAIDAMOUNT) SELLUNPAIDAMOUNT," +
  1308. " sum(t.SELLTODAYINVOICEAMOUNT) SELLTODAYINVOICEAMOUNT," +
  1309. " sum(t.SELLPREINVOICEDAMOUNT) SELLPREINVOICEDAMOUNT," +
  1310. " sum(t.SELLUNINVOICEDAMOUNT) SELLUNINVOICEDAMOUNT," +
  1311. " sum(t.TODAYRECEIVESUM) TODAYRECEIVESUM," +
  1312. " sum(t.TODAYPAYSUM) TODAYPAYSUM" +
  1313. " FROM REPORT_ERMCP_AREAFINANCE t" +
  1314. " WHERE 1 = 1 %v" +
  1315. " GROUP BY %v"
  1316. sqlId.FormatParam(strFileds, sqlParam.String(), strFileds)
  1317. }
  1318. return sqlId.String()
  1319. }
  1320. // GetDataEx 获取财务报表
  1321. func (r *Ermcp3FinanceReport) GetDataEx() (interface{}, error) {
  1322. sData := make([]Ermcp3FinanceReport, 0)
  1323. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  1324. for i := range sData {
  1325. sData[i].calc()
  1326. sData[i].BeginDate = r.BeginDate
  1327. sData[i].EndDate = r.EndDate
  1328. }
  1329. return sData, err
  1330. }
  1331. // Ermcp3AreaStockReportEx 库存报表
  1332. type Ermcp3AreaStockReportEx struct {
  1333. RECKONDATE string `json:"reckondate" xorm:"RECKONDATE"` // 日照时期(yyyyMMdd)
  1334. CYCLETIME string `json:"cycletime" xorm:"CYCLETIME"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  1335. CYCLETYPE int32 `json:"cycletype" xorm:"CYCLETYPE"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  1336. USERID int64 `json:"userid" xorm:"'USERID'"` // 机构ID
  1337. WRSTANDARDID int32 `json:"wrstandardid" xorm:"'WRSTANDARDID'"` // 品类ID
  1338. SPOTGOODSBRANDID int32 `json:"spotgoodsbrandid" xorm:"'SPOTGOODSBRANDID'"` // 现货品牌ID
  1339. WAREHOUSEINFOID string `json:"warehouseinfoid" xorm:"'WAREHOUSEINFOID'"` // 仓库ID
  1340. ORISTOCK float64 `json:"oristock" xorm:"'ORISTOCK'"` // 期初库存量
  1341. CURSTOCK float64 `json:"curstock" xorm:"'CURSTOCK'"` // 期末库存量
  1342. TODAYBUYINQTY float64 `json:"todaybuyinqty" xorm:"'TODAYBUYINQTY'"` // 今采购入库量
  1343. TODAYPRODUCEINQTY float64 `json:"todayproduceinqty" xorm:"'TODAYPRODUCEINQTY'"` // 今内部入库量
  1344. TODAYSELLOUTQTY float64 `json:"todayselloutqty" xorm:"'TODAYSELLOUTQTY'"` // 今销售出库量
  1345. TODAYPRODUCEOUTQTY float64 `json:"todayproduceoutqty" xorm:"'TODAYPRODUCEOUTQTY'"` // 今内部出库量
  1346. UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  1347. WRSTANDARDNAME string `json:"wrstandardname" xorm:"'WRSTANDARDNAME'"` // 品类名称
  1348. WRSTANDARDCODE string `json:"wrstandardcode" xorm:"'WRSTANDARDCODE'"` // 品类代码
  1349. UNITID int32 `json:"unitid" xorm:"'UNITID'"` // 品类单位id
  1350. BRANDNAME string `json:"brandname" xorm:"'BRANDNAME'"` // 品牌名称
  1351. WAREHOUSENAME string `json:"warehousename" xorm:"'WAREHOUSENAME'"` // 仓库名称
  1352. WAREHOUSECODE string `json:"warehousecode" xorm:"'WAREHOUSECODE'"` // 仓库代码
  1353. WAREHOUSETYPE int32 `json:"warehousetype" xorm:"'WAREHOUSETYPE'"` // 仓库类型 - 1 厂库 2 自有库 3 合作库
  1354. USERNAME string `json:"username"` // 机构名称
  1355. ENUMDICNAME string `json:"enumdicname"` // 单位名称
  1356. DELIVERYGOODSID int32 `json:"deliverygoodsid" xorm:"'DELIVERYGOODSID'"` // 现货品种id
  1357. DELIVERYGOODSCODE string `json:"deliverygoodscode" xorm:"'DELIVERYGOODSCODE'"` // 现货品种代码
  1358. DELIVERYGOODSNAME string `json:"deliverygoodsname" xorm:"'DELIVERYGOODSNAME'"` // 现货品种名称
  1359. GOODSUNITID int32 `json:"goodsunitid" xorm:"'GOODSUNITID'"` // 现货单位id
  1360. UNBUYINQTY float64 `json:"unbuyinqty"` // 采购未入库量(数据库未找到相关字段?)
  1361. UNSELLOUTQTY float64 `json:"unselloutqty"` // 销售未出库量(数据库未找到相关字段?)
  1362. DiffQty float64 `json:"diffqty"` // 库存变化量 = 期末 - 期初
  1363. BeginDate string `json:"begindate"` // 开始交易日
  1364. EndDate string `json:"enddate"` // 结束交易日
  1365. SumFields string `json:"-"` // 汇总维度(逗号隔开) 1-品种 2-品类 3-品牌 4-仓库
  1366. }
  1367. func (r *Ermcp3AreaStockReportEx) calc() {
  1368. r.USERNAME = mtpcache.GetUserNameByUserId(r.USERID)
  1369. r.ENUMDICNAME = mtpcache.GetEnumDicitemName(r.UNITID)
  1370. r.DiffQty = r.CURSTOCK - r.ORISTOCK
  1371. }
  1372. // getSumField 获取汇总维度字段
  1373. func (r *Ermcp3AreaStockReportEx) getSumField() (fields []string, bSum bool) {
  1374. fields = append(fields, "userid")
  1375. if r.CYCLETYPE == 0 {
  1376. // 日报表
  1377. fields = append(fields, "reckondate")
  1378. } else {
  1379. // 周期报表
  1380. fields = append(fields, "cycletype")
  1381. fields = append(fields, "cycletime")
  1382. }
  1383. baseField := map[string]string{
  1384. "1": "deliverygoodsid",
  1385. "2": "wrstandardid",
  1386. "3": "spotgoodsbrandid",
  1387. "4": "warehouseinfoid",
  1388. }
  1389. bSum = false
  1390. param := []string{}
  1391. if len(r.SumFields) > 0 {
  1392. param = strings.Split(r.SumFields, ",")
  1393. }
  1394. if len(param) == 0 {
  1395. // 全字段, 不需要汇总
  1396. for _, v := range baseField {
  1397. fields = append(fields, v)
  1398. }
  1399. bSum = false
  1400. } else {
  1401. bIncludeAll := true
  1402. // 判断是否包含所有维度
  1403. for k := range baseField {
  1404. bExist := false
  1405. for _, p := range param {
  1406. if k == p {
  1407. bExist = true
  1408. break
  1409. }
  1410. }
  1411. if !bExist {
  1412. bIncludeAll = false
  1413. break
  1414. }
  1415. }
  1416. if bIncludeAll {
  1417. // 包含了所有维度, 不需要汇总
  1418. for _, v := range baseField {
  1419. fields = append(fields, v)
  1420. }
  1421. bSum = false
  1422. } else {
  1423. tmp := map[string]string{}
  1424. for _, p := range param {
  1425. if v, ok := baseField[p]; ok {
  1426. // 利用map特性去重, 先保存在一个临时map中
  1427. tmp[p] = v
  1428. bSum = true
  1429. }
  1430. }
  1431. if bSum {
  1432. for _, v := range tmp {
  1433. fields = append(fields, v)
  1434. }
  1435. }
  1436. }
  1437. }
  1438. return
  1439. }
  1440. func (r *Ermcp3AreaStockReportEx) getExFieldInfo() (strFiled string, strleftJoin string) {
  1441. if len(r.SumFields) > 0 {
  1442. param := strings.Split(r.SumFields, ",")
  1443. fHas := func(v string) bool {
  1444. for i := range param {
  1445. if param[i] == v {
  1446. return true
  1447. }
  1448. }
  1449. return false
  1450. }
  1451. if fHas("1") {
  1452. if len(strFiled) > 0 {
  1453. strFiled += ","
  1454. }
  1455. strFiled += "g.deliverygoodscode, g.deliverygoodsname, g.goodsunitid"
  1456. strleftJoin += " LEFT JOIN deliverygoods g on a.deliverygoodsid = g.deliverygoodsid"
  1457. }
  1458. if fHas("2") {
  1459. if len(strFiled) > 0 {
  1460. strFiled += ","
  1461. }
  1462. strFiled += "w.wrstandardname, w.wrstandardcode, w.unitid"
  1463. strleftJoin += " LEFT JOIN WRSTANDARD w on a.wrstandardid = w.wrstandardid"
  1464. }
  1465. if fHas("3") {
  1466. if len(strFiled) > 0 {
  1467. strFiled += ","
  1468. }
  1469. strFiled += "gb.dgfactoryitemvalue brandname"
  1470. strleftJoin += " LEFT JOIN dgfactoryitem gb on a.spotgoodsbrandid = gb.dgfactoryitemid"
  1471. }
  1472. if fHas("4") {
  1473. if len(strFiled) > 0 {
  1474. strFiled += ","
  1475. }
  1476. strFiled += "h.warehousecode, h.warehousename, h.warehousetype"
  1477. strleftJoin += " LEFT JOIN WAREHOUSEINFO h on a.warehouseinfoid=h.autoid"
  1478. }
  1479. }
  1480. return
  1481. }
  1482. func (r *Ermcp3AreaStockReportEx) buildSql() (sqlId string) {
  1483. fields, bSum := r.getSumField()
  1484. if r.CYCLETYPE == 0 {
  1485. // 日报表
  1486. if bSum {
  1487. sqlId = r.buildSqlReckonSum(fields)
  1488. } else {
  1489. sqlId = r.buildSqlReckon()
  1490. }
  1491. } else {
  1492. // 周期报表
  1493. if bSum {
  1494. sqlId = r.buildSqlReportSum(fields)
  1495. } else {
  1496. sqlId = r.buildSqlReport()
  1497. }
  1498. }
  1499. return
  1500. }
  1501. // GetDataEx 获取库存报表
  1502. func (r *Ermcp3AreaStockReportEx) GetDataEx() (interface{}, error) {
  1503. sData := make([]Ermcp3AreaStockReportEx, 0)
  1504. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  1505. for i := range sData {
  1506. sData[i].calc()
  1507. sData[i].BeginDate = r.BeginDate
  1508. sData[i].EndDate = r.EndDate
  1509. }
  1510. return sData, err
  1511. }
  1512. // buildSqlReckon 日照表
  1513. func (r *Ermcp3AreaStockReportEx) buildSqlReckon() string {
  1514. var sqlId utils.SQLVal = "SELECT t.TODAYBUYINQTY," +
  1515. " t.TODAYPRODUCEINQTY," +
  1516. " t.reckondate," +
  1517. " t.TODAYSELLOUTQTY," +
  1518. " t.TODAYPRODUCEOUTQTY," +
  1519. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  1520. " t.USERID," +
  1521. " t.WRSTANDARDID," +
  1522. " t.SPOTGOODSBRANDID," +
  1523. " t.WAREHOUSEINFOID," +
  1524. " t.deliverygoodsid," +
  1525. " t.ORISTOCK," +
  1526. " t.CURSTOCK," +
  1527. " w.wrstandardname," +
  1528. " w.wrstandardcode," +
  1529. " w.unitid," +
  1530. " gb.dgfactoryitemvalue brandname," +
  1531. " h.warehousename," +
  1532. " h.warehousecode," +
  1533. " h.warehousetype," +
  1534. " g.deliverygoodscode," +
  1535. " g.deliverygoodsname," +
  1536. " g.goodsunitid" +
  1537. " FROM RECKON_ERMCP_AREASTOCK t" +
  1538. " LEFT JOIN WRSTANDARD w" +
  1539. " on t.wrstandardid = w.wrstandardid" +
  1540. " LEFT JOIN dgfactoryitem gb" +
  1541. " on t.spotgoodsbrandid = gb.dgfactoryitemid" +
  1542. " LEFT JOIN deliverygoods g" +
  1543. " on t.deliverygoodsid = g.deliverygoodsid" +
  1544. " LEFT JOIN WAREHOUSEINFO h" +
  1545. " on t.warehouseinfoid = h.autoid" +
  1546. " WHERE 1 = 1"
  1547. sqlId.And("t.USERID", r.USERID)
  1548. sqlId.AndEx("t.RECKONDATE", r.RECKONDATE, len(r.RECKONDATE) > 0)
  1549. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  1550. sqlId.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1551. }
  1552. // 现货商品id
  1553. sqlId.AndEx("t.DELIVERYGOODSID", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  1554. // 品类id
  1555. sqlId.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  1556. // 品牌id
  1557. sqlId.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  1558. // 仓库id
  1559. sqlId.AndEx("t.WAREHOUSEINFOID", r.WAREHOUSEINFOID, len(r.WAREHOUSEINFOID) > 0)
  1560. sqlId.Join(" order by t.reckondate")
  1561. return sqlId.String()
  1562. }
  1563. // buildSqlReckonSum 日照表(汇总维度)
  1564. func (r *Ermcp3AreaStockReportEx) buildSqlReckonSum(fields []string) string {
  1565. var sqlId utils.SQLVal = "SELECT a.*, %v" +
  1566. " from (SELECT %v," +
  1567. " sum(t.ORISTOCK) ORISTOCK," +
  1568. " sum(t.CURSTOCK) CURSTOCK," +
  1569. " sum(t.TODAYBUYINQTY) TODAYBUYINQTY," +
  1570. " sum(t.TODAYPRODUCEINQTY) TODAYPRODUCEINQTY," +
  1571. " sum(t.TODAYSELLOUTQTY) TODAYSELLOUTQTY," +
  1572. " sum(t.TODAYPRODUCEOUTQTY) TODAYPRODUCEOUTQTY" +
  1573. " FROM RECKON_ERMCP_AREASTOCK t" +
  1574. " WHERE 1 = 1 %v" +
  1575. " GROUP BY %v) a %v"
  1576. var sqlParam utils.SQLVal
  1577. sqlParam.And("t.USERID", r.USERID)
  1578. sqlParam.AndEx("t.RECKONDATE", r.RECKONDATE, len(r.RECKONDATE) > 0)
  1579. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  1580. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1581. }
  1582. // 现货商品id
  1583. sqlParam.AndEx("t.DELIVERYGOODSID", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  1584. // 品类id
  1585. sqlParam.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  1586. // 品牌id
  1587. sqlParam.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  1588. // 仓库id
  1589. sqlParam.AndEx("t.WAREHOUSEINFOID", r.WAREHOUSEINFOID, len(r.WAREHOUSEINFOID) > 0)
  1590. var strFileds string
  1591. for _, v := range fields {
  1592. if len(strFileds) > 0 {
  1593. strFileds += ","
  1594. }
  1595. strFileds += "t." + v
  1596. }
  1597. exFields, exLeftJoinTable := r.getExFieldInfo()
  1598. sqlId.FormatParam(exFields, strFileds, sqlParam.String(), strFileds, exLeftJoinTable)
  1599. sqlId.Join(" order by a.reckondate")
  1600. return sqlId.String()
  1601. }
  1602. // buildSqlReport 报表表
  1603. func (r *Ermcp3AreaStockReportEx) buildSqlReport() string {
  1604. var sqlId utils.SQLVal = "SELECT t.TODAYBUYINQTY," +
  1605. " t.TODAYPRODUCEINQTY," +
  1606. " t.cycletype," +
  1607. " t.cycletime," +
  1608. " t.USERID," +
  1609. " t.WRSTANDARDID," +
  1610. " t.SPOTGOODSBRANDID," +
  1611. " t.WAREHOUSEINFOID," +
  1612. " t.deliverygoodsid," +
  1613. " t.TODAYSELLOUTQTY," +
  1614. " t.TODAYPRODUCEOUTQTY," +
  1615. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  1616. " t.ORISTOCK," +
  1617. " t.CURSTOCK," +
  1618. " w.wrstandardname," +
  1619. " w.wrstandardcode," +
  1620. " w.unitid," +
  1621. " gb.dgfactoryitemvalue brandname," +
  1622. " h.warehousename," +
  1623. " h.warehousecode," +
  1624. " h.warehousetype," +
  1625. " g.deliverygoodscode," +
  1626. " g.deliverygoodsname," +
  1627. " g.goodsunitid" +
  1628. " FROM REPORT_ERMCP_AREASTOCK t" +
  1629. " LEFT JOIN WRSTANDARD w" +
  1630. " on t.wrstandardid = w.wrstandardid" +
  1631. " LEFT JOIN dgfactoryitem gb" +
  1632. " on t.spotgoodsbrandid = gb.dgfactoryitemid" +
  1633. " LEFT JOIN deliverygoods g" +
  1634. " on t.deliverygoodsid = g.deliverygoodsid" +
  1635. " LEFT JOIN WAREHOUSEINFO h" +
  1636. " on t.warehouseinfoid = h.autoid" +
  1637. " WHERE 1 = 1"
  1638. sqlId.And("t.USERID", r.USERID)
  1639. sqlId.And("t.cycletype", r.CYCLETYPE)
  1640. sqlId.And("t.cycletime", r.CYCLETIME)
  1641. // 现货商品id
  1642. sqlId.AndEx("t.DELIVERYGOODSID", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  1643. // 品类id
  1644. sqlId.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  1645. // 品牌id
  1646. sqlId.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  1647. // 仓库id
  1648. sqlId.AndEx("t.WAREHOUSEINFOID", r.WAREHOUSEINFOID, len(r.WAREHOUSEINFOID) > 0)
  1649. return sqlId.String()
  1650. }
  1651. // buildSqlReport 报表表(汇总维度)
  1652. func (r *Ermcp3AreaStockReportEx) buildSqlReportSum(fields []string) string {
  1653. var sqlId utils.SQLVal = "SELECT a.*, %v" +
  1654. " from (SELECT %v," +
  1655. " sum(t.ORISTOCK) ORISTOCK," +
  1656. " sum(t.CURSTOCK) CURSTOCK," +
  1657. " sum(t.TODAYBUYINQTY) TODAYBUYINQTY," +
  1658. " sum(t.TODAYPRODUCEINQTY) TODAYPRODUCEINQTY," +
  1659. " sum(t.TODAYSELLOUTQTY) TODAYSELLOUTQTY," +
  1660. " sum(t.TODAYPRODUCEOUTQTY) TODAYPRODUCEOUTQTY" +
  1661. " FROM REPORT_ERMCP_AREASTOCK t" +
  1662. " WHERE 1 = 1 %v" +
  1663. " GROUP BY %v) a %v"
  1664. var sqlParam utils.SQLVal
  1665. sqlParam.And("t.USERID", r.USERID)
  1666. sqlParam.And("t.cycletype", r.CYCLETYPE)
  1667. sqlParam.And("t.cycletime", r.CYCLETIME)
  1668. // 现货商品id
  1669. sqlParam.AndEx("t.DELIVERYGOODSID", r.DELIVERYGOODSID, r.DELIVERYGOODSID > 0)
  1670. // 品类id
  1671. sqlParam.AndEx("t.WRSTANDARDID", r.WRSTANDARDID, r.WRSTANDARDID > 0)
  1672. // 品牌id
  1673. sqlParam.AndEx("t.SPOTGOODSBRANDID", r.SPOTGOODSBRANDID, r.SPOTGOODSBRANDID > 0)
  1674. // 仓库id
  1675. sqlParam.AndEx("t.WAREHOUSEINFOID", r.WAREHOUSEINFOID, len(r.WAREHOUSEINFOID) > 0)
  1676. var strFileds string
  1677. for _, v := range fields {
  1678. if len(strFileds) > 0 {
  1679. strFileds += ","
  1680. }
  1681. strFileds += "t." + v
  1682. }
  1683. exFields, exLeftJoinTable := r.getExFieldInfo()
  1684. sqlId.FormatParam(exFields, strFileds, sqlParam.String(), strFileds, exLeftJoinTable)
  1685. return sqlId.String()
  1686. }
  1687. // Ermcp3ArealSumPL 损益汇总表
  1688. type Ermcp3ArealSumPL struct {
  1689. RECKONDATE string `json:"reckondate" xorm:"RECKONDATE"` // 日照时期(yyyyMMdd)
  1690. CYCLETIME string `json:"cycletime" xorm:"'CYCLETIME'"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  1691. CYCLETYPE int32 `json:"cycletype" xorm:"'CYCLETYPE'"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  1692. AREAUSERID int64 `json:"areauserid" xorm:"AREAUSERID"` // 所属机构\交易用户ID
  1693. MIDDLEGOODSID int64 `json:"middlegoodsid" xorm:"MIDDLEGOODSID"` // 套保品种ID(SEQ_ERMS_MIDDLEGOODS)
  1694. CURRENCYID int32 `json:"currencyid" xorm:"CURRENCYID"` // 结算币种ID
  1695. SPOTACTUALPL float64 `json:"spotactualpl" xorm:"SPOTACTUALPL"` // 现货损益
  1696. SPOTFLOATPL float64 `json:"spotfloatpl" xorm:"SPOTFLOATPL"` // 现货浮动损益
  1697. FUTUREACTUALPL float64 `json:"futureactualpl" xorm:"FUTUREACTUALPL"` // 期货损益
  1698. FUTUREFLOATPL float64 `json:"futurefloatpl" xorm:"FUTUREFLOATPL"` // 期货浮动损益
  1699. SUMACTUALPL float64 `json:"sumactualpl" xorm:"SUMACTUALPL"` // 实际损益 = (ActualPL + FutureActualPL)
  1700. SUMPL float64 `json:"sumpl" xorm:"'SUMPL'"` // 汇总损益
  1701. UPDATETIME string `json:"updatetime" xorm:"UPDATETIME"` // 更新时间
  1702. MIDDLEGOODSNAME string `json:"middlegoodsname" xorm:"'MIDDLEGOODSNAME'"` // 套保品种名称
  1703. MIDDLEGOODSCODE string `json:"middlegoodscode" xorm:"'MIDDLEGOODSCODE'"` // 套保品种代码
  1704. GOODSUNITID int32 `json:"goodsunitid" xorm:"'GOODSUNITID'"` // 套保品种单位id
  1705. ACCOUNTNAME string `json:"accountname"` // 机构名称
  1706. ENUMDICNAME string `json:"enumdicname"` // 单位名称(套保品种)
  1707. CURRENCYNAME string `json:"currencyname"` // 币种名称
  1708. QueryType int32 `json:"-"` // 查询类型 1-报表 2-报表明细
  1709. BeginDate string `json:"begindate"` // 开始交易日
  1710. EndDate string `json:"enddate"` // 结束交易日
  1711. }
  1712. func (r *Ermcp3ArealSumPL) calc() {
  1713. r.CURRENCYNAME = mtpcache.GetCurrencyName(r.CURRENCYID)
  1714. r.ENUMDICNAME = mtpcache.GetEnumDicitemName(r.GOODSUNITID)
  1715. r.ACCOUNTNAME = mtpcache.GetUserNameByUserId(r.AREAUSERID)
  1716. }
  1717. func (r *Ermcp3ArealSumPL) buildSql() string {
  1718. // 日报表
  1719. if r.QueryType == 1 && r.CYCLETYPE == 0 {
  1720. return r.buildSqlDay()
  1721. }
  1722. // 日报表明细
  1723. if r.QueryType == 2 && r.CYCLETYPE == 0 {
  1724. return r.buildSqlDayDetail()
  1725. }
  1726. return r.buildSqlCycle()
  1727. }
  1728. // buildSqlDay 损益汇总日报表(需要汇总维度)
  1729. func (r *Ermcp3ArealSumPL) buildSqlDay() string {
  1730. var sqlId utils.SQLVal = "SELECT t.RECKONDATE," +
  1731. " t.AREAUSERID," +
  1732. " t.CURRENCYID," +
  1733. " sum(t.SPOTACTUALPL) SPOTACTUALPL," +
  1734. " sum(t.SPOTFLOATPL) SPOTFLOATPL," +
  1735. " sum(t.FUTUREACTUALPL) FUTUREACTUALPL," +
  1736. " sum(t.FUTUREFLOATPL) FUTUREFLOATPL," +
  1737. " sum(t.SUMACTUALPL) SUMACTUALPL," +
  1738. " sum(t.SUMPL) SUMPL" +
  1739. " FROM RECKON_ERMCP_AREASUMPL t" +
  1740. " WHERE 1 = 1"
  1741. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  1742. if r.QueryType == 1 {
  1743. sqlId.And("t.RECKONDATE", r.RECKONDATE)
  1744. } else if r.QueryType == 2 {
  1745. sqlId.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1746. }
  1747. sqlId.Join(" GROUP BY t.RECKONDATE, t.AREAUSERID, t.CURRENCYID")
  1748. return sqlId.String()
  1749. }
  1750. func (r *Ermcp3ArealSumPL) buildSqlDayDetail() string {
  1751. var sqlId utils.SQLVal = "SELECT t.RECKONDATE," +
  1752. " t.AREAUSERID," +
  1753. " t.MIDDLEGOODSID," +
  1754. " t.CURRENCYID," +
  1755. " t.SPOTACTUALPL," +
  1756. " t.SPOTFLOATPL," +
  1757. " t.FUTUREACTUALPL," +
  1758. " t.FUTUREFLOATPL," +
  1759. " t.SUMACTUALPL," +
  1760. " t.SUMPL," +
  1761. " to_char(t.UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  1762. " g.middlegoodsname," +
  1763. " g.middlegoodscode," +
  1764. " g.goodsunitid" +
  1765. " FROM RECKON_ERMCP_AREASUMPL t" +
  1766. " LEFT JOIN ERMS_MIDDLEGOODS g on t.middlegoodsid=g.middlegoodsid" +
  1767. " WHERE 1 = 1"
  1768. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  1769. sqlId.AndEx("t.RECKONDATE", r.RECKONDATE, len(r.RECKONDATE) > 0)
  1770. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  1771. sqlId.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1772. }
  1773. sqlId.And("t.CURRENCYID", r.CURRENCYID)
  1774. return sqlId.String()
  1775. }
  1776. func (r *Ermcp3ArealSumPL) buildSqlCycle() string {
  1777. var sqlId utils.SQLVal = "SELECT t.AREAUSERID," +
  1778. " t.CYCLETIME," +
  1779. " t.CYCLETYPE," +
  1780. " t.CURRENCYID," +
  1781. " sum(t.SPOTACTUALPL) SPOTACTUALPL," +
  1782. " sum(t.SPOTFLOATPL) SPOTFLOATPL," +
  1783. " sum(t.FUTUREACTUALPL) FUTUREACTUALPL," +
  1784. " sum(t.FUTUREFLOATPL) FUTUREFLOATPL," +
  1785. " sum(t.SUMACTUALPL) SUMACTUALPL," +
  1786. " sum(t.SUMPL) SUMPL" +
  1787. " FROM REPORT_ERMCP_AREASUMPL t" +
  1788. " WHERE 1 = 1"
  1789. sqlId.And("t.AREAUSERID", r.AREAUSERID)
  1790. sqlId.And("t.cycletype", r.CYCLETYPE)
  1791. sqlId.And("t.cycletime", r.CYCLETIME)
  1792. sqlId.Join(" GROUP BY t.AREAUSERID, t.CURRENCYID, t.CYCLETIME, t.CYCLETYPE")
  1793. return sqlId.String()
  1794. }
  1795. // GetDataEx 获取损益汇总表
  1796. func (r *Ermcp3ArealSumPL) GetDataEx() (interface{}, error) {
  1797. sData := make([]Ermcp3ArealSumPL, 0)
  1798. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  1799. for i := range sData {
  1800. sData[i].calc()
  1801. sData[i].BeginDate = r.BeginDate
  1802. sData[i].EndDate = r.EndDate
  1803. }
  1804. return sData, err
  1805. }
  1806. // Ermcp3TaFutuReDataReport 期货报表
  1807. type Ermcp3TaFutuReDataReport struct {
  1808. RECKONDATE string `json:"reckondate" xorm:"RECKONDATE"` // 日照时期(yyyyMMdd)
  1809. CYCLETIME string `json:"cycletime" xorm:"CYCLETIME"` // 周期时间 月(YYYYMM) 季(YYYYQ) 年(YYYY) 周(YYYYIW) 全(0)【原值】
  1810. CYCLETYPE int32 `json:"cycletype" xorm:"CYCLETYPE"` // 周期类型 - 1:月 2:季 3:年 4:周 5:全报表【原值】
  1811. ACCOUNTID int64 `json:"accountid" xorm:"ACCOUNTID"` // 交易账户
  1812. GOODSID string `json:"goodsid" xorm:"GOODSID"` // 交易合约
  1813. BUYORSELL int32 `json:"buyorsell" xorm:"BUYORSELL"` // 持仓方向
  1814. CURRENCYID string `json:"currencyid" xorm:"CURRENCYID"` // 结算币种ID
  1815. USERID int64 `json:"userid" xorm:"USERID"` // 账户所属用户ID
  1816. RELATEDUSERID string `json:"relateduserid" xorm:"RELATEDUSERID"` // 账户关联用户ID
  1817. GOODSGROUPID string `json:"goodsgroupid" xorm:"GOODSGROUPID"` // 交易品种
  1818. ORIHOLDQTY float64 `json:"oriholdqty" xorm:"ORIHOLDQTY"` // 期初持仓量
  1819. ORIOPENAMOUNT float64 `json:"oriopenamount" xorm:"ORIOPENAMOUNT"` // 期初开仓额
  1820. ORIHOLDAMOUNT float64 `json:"oriholdamount" xorm:"ORIHOLDAMOUNT"` // 期初持仓额
  1821. TODAYOPENQTY float64 `json:"todayopenqty" xorm:"TODAYOPENQTY"` // 今开仓量
  1822. TODAYOPENAMOUNT float64 `json:"todayopenamount" xorm:"TODAYOPENAMOUNT"` // 今开仓额
  1823. TODAYCLOSEQTY float64 `json:"todaycloseqty" xorm:"TODAYCLOSEQTY"` // 今平仓量
  1824. TODAYCLOSEAMOUNT float64 `json:"todaycloseamount" xorm:"TODAYCLOSEAMOUNT"` // 今平仓额
  1825. HOLDQTY float64 `json:"holdqty" xorm:"HOLDQTY"` // 期末持仓量
  1826. OPENAMOUNT float64 `json:"openamount" xorm:"OPENAMOUNT"` // 期末开仓额
  1827. HOLDAMOUNT float64 `json:"holdamount" xorm:"HOLDAMOUNT"` // 期末持仓额
  1828. RECKONPRICE float64 `json:"reckonprice" xorm:"RECKONPRICE"` // 结算价
  1829. RECKONHOLDAMOUNT float64 `json:"reckonholdamount" xorm:"RECKONHOLDAMOUNT"` // 结算持仓额
  1830. CHARGE float64 `json:"charge" xorm:"CHARGE"` // 手续费
  1831. CLOSEPL float64 `json:"closepl" xorm:"CLOSEPL"` // 平仓损益
  1832. RECKONPL float64 `json:"reckonpl" xorm:"RECKONPL"` // 结算损益
  1833. LASTPRICE float64 `json:"lastprice" xorm:"LASTPRICE"` // 最新价
  1834. LASTHOLDAMOUNT float64 `json:"lastholdamount" xorm:"LASTHOLDAMOUNT"` // 当前持仓额
  1835. FLOATPL float64 `json:"floatpl" xorm:"FLOATPL"` // 浮动损益
  1836. GOODSGROUPSPOTQTY float64 `json:"goodsgroupspotqty" xorm:"GOODSGROUPSPOTQTY"` // 交易品种期末量 (= 期末持仓量 * 合约乘数)
  1837. TODAYGOODSGROUPSPOTQTY float64 `json:"todaygoodsgroupspotqty" xorm:"TODAYGOODSGROUPSPOTQTY"` // 交易品种变化量 (=(期末持仓量 - 期初持仓量)* 合约乘数)
  1838. MIDDLEGOODSQTY float64 `json:"middlegoodsqty" xorm:"MIDDLEGOODSQTY"` // 套保品种期末量 (=交易品种期末量 * 期货品种折算系数)
  1839. TODAYMIDDLEGOODSQTY float64 `json:"todaymiddlegoodsqty" xorm:"TODAYMIDDLEGOODSQTY"` // 套保品种变化量 (= 交易品种变化量*期货品种折算系数)
  1840. RECKONPL2 float64 `json:"reckonpl2" xorm:"RECKONPL2"` // 结算逐笔盈亏
  1841. OUTERGROUPCODE string `json:"outergroupcode" xorm:"'OUTERGROUPCODE'"` // 交易品种代码
  1842. GOODSGROUPNAME string `json:"goodsgroupname" xorm:"'GOODSGROUPNAME'"` // 交易品种名称
  1843. GOODSCODE string `json:"goodscode" xorm:"'GOODSCODE'"` // 交易合约代码
  1844. GOODSNAME string `json:"goodsname" xorm:"'GOODSNAME'"` // 交易合约名称
  1845. GOODUNITID int32 `json:"goodunitid" xorm:"'GOODUNITID'"` // 交易合约单位id
  1846. ACCOUNTNAME string `json:"accountname" xorm:"'ACCOUNTNAME'"` // 交易账号名称
  1847. ENUMDICNAME string `json:"enumdicname"` // 单位名称(现货商品)
  1848. QueryType int32 `json:"-"` // 查询类型 1-报表 2-报表明细
  1849. BeginDate string `json:"begindate"` // 开始交易日
  1850. EndDate string `json:"enddate"` // 结束交易日
  1851. }
  1852. func (r *Ermcp3TaFutuReDataReport) calc() {
  1853. }
  1854. func (r *Ermcp3TaFutuReDataReport) userType() int32 {
  1855. var userType int32 = 2
  1856. areaUserId := mtpcache.GetAreaUserId(r.USERID, 0)
  1857. if areaUserId == r.USERID {
  1858. userType = 2
  1859. } else {
  1860. userType = 7
  1861. }
  1862. return userType
  1863. }
  1864. func (r *Ermcp3TaFutuReDataReport) buildSql() string {
  1865. userType := r.userType()
  1866. // 日报表
  1867. if r.QueryType == 1 && r.CYCLETYPE == 0 {
  1868. return r.buildSqlReckon(userType)
  1869. }
  1870. // 日报表明细
  1871. if r.QueryType == 2 && r.CYCLETYPE == 0 {
  1872. return r.buildSqlReckonDetail(userType)
  1873. }
  1874. return r.buildSqlReport(userType)
  1875. }
  1876. // buildSqlReckon 日照表
  1877. func (r *Ermcp3TaFutuReDataReport) buildSqlReckon(userType int32) string {
  1878. var sqlId utils.SQLVal = "select a.*," +
  1879. " gp.outergroupcode," +
  1880. " gp.goodsgroupname," +
  1881. " g.goodscode," +
  1882. " g.goodsname," +
  1883. " g.goodunitid" +
  1884. " from (SELECT t.RECKONDATE," +
  1885. " t.GOODSID," +
  1886. " t.BUYORSELL," +
  1887. " t.CURRENCYID," +
  1888. " t.%v USERID," +
  1889. " t.GOODSGROUPID," +
  1890. " sum(t.ORIHOLDQTY) ORIHOLDQTY," +
  1891. " sum(t.ORIOPENAMOUNT) ORIOPENAMOUNT," +
  1892. " sum(t.ORIHOLDAMOUNT) ORIHOLDAMOUNT," +
  1893. " sum(t.TODAYOPENQTY) TODAYOPENQTY," +
  1894. " sum(t.TODAYOPENAMOUNT) TODAYOPENAMOUNT," +
  1895. " sum(t.TODAYCLOSEQTY) TODAYCLOSEQTY," +
  1896. " sum(t.TODAYCLOSEAMOUNT) TODAYCLOSEAMOUNT," +
  1897. " sum(t.HOLDQTY) HOLDQTY," +
  1898. " sum(t.OPENAMOUNT) OPENAMOUNT," +
  1899. " sum(t.HOLDAMOUNT) HOLDAMOUNT," +
  1900. " sum(t.RECKONPRICE) RECKONPRICE," +
  1901. " sum(t.RECKONHOLDAMOUNT) RECKONHOLDAMOUNT," +
  1902. " sum(t.CHARGE) CHARGE," +
  1903. " sum(t.CLOSEPL) CLOSEPL," +
  1904. " sum(t.RECKONPL) RECKONPL," +
  1905. " sum(t.LASTPRICE) LASTPRICE," +
  1906. " sum(t.LASTHOLDAMOUNT) LASTHOLDAMOUNT," +
  1907. " sum(t.FLOATPL) FLOATPL," +
  1908. " sum(t.GOODSGROUPSPOTQTY) GOODSGROUPSPOTQTY," +
  1909. " sum(t.TODAYGOODSGROUPSPOTQTY) TODAYGOODSGROUPSPOTQTY," +
  1910. " sum(t.MIDDLEGOODSQTY) MIDDLEGOODSQTY," +
  1911. " sum(t.TODAYMIDDLEGOODSQTY) TODAYMIDDLEGOODSQTY," +
  1912. " sum(t.Reckonpl2) RECKONPL2" +
  1913. " FROM RECKON_ERMCP_TAFUTUREDATA t" +
  1914. " WHERE 1 = 1 %v" +
  1915. " GROUP BY t.RECKONDATE," +
  1916. " t.GOODSID," +
  1917. " t.BUYORSELL," +
  1918. " t.CURRENCYID," +
  1919. " t.%v," +
  1920. " t.GOODSGROUPID) a" +
  1921. " left join goodsgroup gp" +
  1922. " on a.goodsgroupid = gp.goodsgroupid" +
  1923. " left join goods g" +
  1924. " on a.goodsid = g.goodsid"
  1925. userId := "USERID"
  1926. var sqlParam utils.SQLVal
  1927. if userType == 2 {
  1928. sqlParam.AndEx("t.userid", r.USERID, userType == 2)
  1929. userId = "USERID"
  1930. } else if userType == 7 {
  1931. sqlParam.AndEx("t.relateduserid", r.USERID, userType == 7)
  1932. userId = "RELATEDUSERID"
  1933. }
  1934. sqlParam.AndEx("t.reckondate", r.RECKONDATE, len(r.RECKONDATE) > 0)
  1935. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  1936. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  1937. }
  1938. sqlId.FormatParam(userId, sqlParam.String(), userId)
  1939. return sqlId.String()
  1940. }
  1941. // buildSqlReckon 日照表明细
  1942. func (r *Ermcp3TaFutuReDataReport) buildSqlReckonDetail(userType int32) string {
  1943. var sqlId utils.SQLVal = "select a.*," +
  1944. " gp.outergroupcode," +
  1945. " gp.goodsgroupname," +
  1946. " g.goodscode," +
  1947. " g.goodsname," +
  1948. " g.goodunitid," +
  1949. " ta.accountname" +
  1950. " from (SELECT t.reckondate," +
  1951. " t.GOODSID," +
  1952. " t.BUYORSELL," +
  1953. " t.CURRENCYID," +
  1954. " t.%v USERID," +
  1955. " t.accountid," +
  1956. " t.GOODSGROUPID," +
  1957. " sum(t.ORIHOLDQTY) ORIHOLDQTY," +
  1958. " sum(t.ORIOPENAMOUNT) ORIOPENAMOUNT," +
  1959. " sum(t.ORIHOLDAMOUNT) ORIHOLDAMOUNT," +
  1960. " sum(t.TODAYOPENQTY) TODAYOPENQTY," +
  1961. " sum(t.TODAYOPENAMOUNT) TODAYOPENAMOUNT," +
  1962. " sum(t.TODAYCLOSEQTY) TODAYCLOSEQTY," +
  1963. " sum(t.TODAYCLOSEAMOUNT) TODAYCLOSEAMOUNT," +
  1964. " sum(t.HOLDQTY) HOLDQTY," +
  1965. " sum(t.OPENAMOUNT) OPENAMOUNT," +
  1966. " sum(t.HOLDAMOUNT) HOLDAMOUNT," +
  1967. " sum(t.RECKONPRICE) RECKONPRICE," +
  1968. " sum(t.RECKONHOLDAMOUNT) RECKONHOLDAMOUNT," +
  1969. " sum(t.CHARGE) CHARGE," +
  1970. " sum(t.CLOSEPL) CLOSEPL," +
  1971. " sum(t.RECKONPL) RECKONPL," +
  1972. " sum(t.LASTPRICE) LASTPRICE," +
  1973. " sum(t.LASTHOLDAMOUNT) LASTHOLDAMOUNT," +
  1974. " sum(t.FLOATPL) FLOATPL," +
  1975. " sum(t.GOODSGROUPSPOTQTY) GOODSGROUPSPOTQTY," +
  1976. " sum(t.TODAYGOODSGROUPSPOTQTY) TODAYGOODSGROUPSPOTQTY," +
  1977. " sum(t.MIDDLEGOODSQTY) MIDDLEGOODSQTY," +
  1978. " sum(t.TODAYMIDDLEGOODSQTY) TODAYMIDDLEGOODSQTY," +
  1979. " sum(t.Reckonpl2) RECKONPL2" +
  1980. " FROM RECKON_ERMCP_TAFUTUREDATA t" +
  1981. " WHERE 1 = 1 %v" +
  1982. " GROUP BY t.reckondate," +
  1983. " t.GOODSID," +
  1984. " t.BUYORSELL," +
  1985. " t.CURRENCYID," +
  1986. " t.%v," +
  1987. " t.accountid," +
  1988. " t.GOODSGROUPID) a" +
  1989. " left join goodsgroup gp" +
  1990. " on a.goodsgroupid = gp.goodsgroupid" +
  1991. " left join goods g" +
  1992. " on a.goodsid = g.goodsid" +
  1993. " left join taaccount ta on a.accountid = ta.accountid"
  1994. userId := "USERID"
  1995. var sqlParam utils.SQLVal
  1996. if userType == 2 {
  1997. sqlParam.AndEx("t.userid", r.USERID, userType == 2)
  1998. userId = "USERID"
  1999. } else if userType == 7 {
  2000. sqlParam.AndEx("t.relateduserid", r.USERID, userType == 7)
  2001. userId = "RELATEDUSERID"
  2002. }
  2003. sqlParam.AndEx("t.reckondate", r.RECKONDATE, len(r.RECKONDATE) > 0)
  2004. if len(r.BeginDate) > 0 && len(r.EndDate) > 0 {
  2005. sqlParam.Join(fmt.Sprintf(" and t.RECKONDATE >= '%v' and t.RECKONDATE <= '%v' ", r.BeginDate, r.EndDate))
  2006. }
  2007. sqlId.FormatParam(userId, sqlParam.String(), userId)
  2008. return sqlId.String()
  2009. }
  2010. // buildSqlReckon 报表表
  2011. func (r *Ermcp3TaFutuReDataReport) buildSqlReport(userType int32) string {
  2012. var sqlId utils.SQLVal = "select a.*," +
  2013. " gp.outergroupcode," +
  2014. " gp.goodsgroupname," +
  2015. " g.goodscode," +
  2016. " g.goodsname," +
  2017. " g.goodunitid" +
  2018. " from (SELECT t.cycletype," +
  2019. " t.cycletime," +
  2020. " t.GOODSID," +
  2021. " t.BUYORSELL," +
  2022. " t.CURRENCYID," +
  2023. " t.%v USERID," +
  2024. " t.GOODSGROUPID," +
  2025. " sum(t.ORIHOLDQTY) ORIHOLDQTY," +
  2026. " sum(t.ORIOPENAMOUNT) ORIOPENAMOUNT," +
  2027. " sum(t.ORIHOLDAMOUNT) ORIHOLDAMOUNT," +
  2028. " sum(t.TODAYOPENQTY) TODAYOPENQTY," +
  2029. " sum(t.TODAYOPENAMOUNT) TODAYOPENAMOUNT," +
  2030. " sum(t.TODAYCLOSEQTY) TODAYCLOSEQTY," +
  2031. " sum(t.TODAYCLOSEAMOUNT) TODAYCLOSEAMOUNT," +
  2032. " sum(t.HOLDQTY) HOLDQTY," +
  2033. " sum(t.OPENAMOUNT) OPENAMOUNT," +
  2034. " sum(t.HOLDAMOUNT) HOLDAMOUNT," +
  2035. " sum(t.RECKONPRICE) RECKONPRICE," +
  2036. " sum(t.RECKONHOLDAMOUNT) RECKONHOLDAMOUNT," +
  2037. " sum(t.CHARGE) CHARGE," +
  2038. " sum(t.CLOSEPL) CLOSEPL," +
  2039. " sum(t.RECKONPL) RECKONPL," +
  2040. " sum(t.LASTPRICE) LASTPRICE," +
  2041. " sum(t.LASTHOLDAMOUNT) LASTHOLDAMOUNT," +
  2042. " sum(t.FLOATPL) FLOATPL," +
  2043. " sum(t.GOODSGROUPSPOTQTY) GOODSGROUPSPOTQTY," +
  2044. " sum(t.TODAYGOODSGROUPSPOTQTY) TODAYGOODSGROUPSPOTQTY," +
  2045. " sum(t.MIDDLEGOODSQTY) MIDDLEGOODSQTY," +
  2046. " sum(t.TODAYMIDDLEGOODSQTY) TODAYMIDDLEGOODSQTY," +
  2047. " sum(t.Reckonpl2) RECKONPL2" +
  2048. " FROM REPORT_ERMCP_TAFUTUREDATA t" +
  2049. " WHERE 1 = 1 %v" +
  2050. " and t.userid = 8888" +
  2051. " and t.cycletype = 1" +
  2052. " and t.cycletime = '202105'" +
  2053. " GROUP BY t.cycletype," +
  2054. " t.cycletime," +
  2055. " t.GOODSID," +
  2056. " t.BUYORSELL," +
  2057. " t.CURRENCYID," +
  2058. " t.%v," +
  2059. " t.GOODSGROUPID) a" +
  2060. " left join goodsgroup gp" +
  2061. " on a.goodsgroupid = gp.goodsgroupid" +
  2062. " left join goods g" +
  2063. " on a.goodsid = g.goodsid"
  2064. userId := "USERID"
  2065. var sqlParam utils.SQLVal
  2066. if userType == 2 {
  2067. sqlParam.AndEx("t.userid", r.USERID, userType == 2)
  2068. userId = "USERID"
  2069. } else if userType == 7 {
  2070. sqlParam.AndEx("t.relateduserid", r.USERID, userType == 7)
  2071. userId = "RELATEDUSERID"
  2072. }
  2073. sqlParam.And("t.cycletype", r.CYCLETYPE)
  2074. sqlParam.And("t.cycletime", r.CYCLETIME)
  2075. sqlId.FormatParam(userId, sqlParam.String(), userId)
  2076. return sqlId.String()
  2077. }
  2078. // GetDataEx 获取期货报表
  2079. func (r *Ermcp3TaFutuReDataReport) GetDataEx() (interface{}, error) {
  2080. sData := make([]Ermcp3TaFutuReDataReport, 0)
  2081. err := db.GetEngine().SQL(r.buildSql()).Find(&sData)
  2082. for i := range sData {
  2083. sData[i].calc()
  2084. sData[i].BeginDate = r.BeginDate
  2085. sData[i].EndDate = r.EndDate
  2086. }
  2087. return sData, err
  2088. }