ermcpOPLog.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /**
  2. * @Author: zou.yingbin
  3. * @Create : 2021/1/14 11:44
  4. * @Modify : 2021/1/14 11:44
  5. */
  6. package models
  7. import (
  8. "fmt"
  9. "mtp2_if/db"
  10. )
  11. // ErmcpOPLogModel 变更变记录
  12. type ErmcpOPLogModel struct {
  13. BIZTYPE int32 `json:"biztype" xorm:"'BIZTYPE'"` // 业务类型 - 1:套保计划 2:现货合同
  14. OPERATELOGTYPE int32 `json:"operatelogtype" xorm:"'OPERATELOGTYPE'"` // 操作流水类型
  15. RELATEDID string `json:"relatedid" xorm:"'RELATEDID'"` // 现货合同ID\套保计划
  16. LOGVALUE float64 `json:"logvalue" xorm:"'LOGVALUE'"` // 数值
  17. BEFOREVALUE float64 `json:"beforevalue" xorm:"'BEFOREVALUE'"` // 变更前
  18. AFTERVALUE float64 `json:"aftervalue" xorm:"'AFTERVALUE'"` // 变更后
  19. UPDATETIME string `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  20. APPLYID string `json:"applyid" xorm:"'APPLYID'"` // 操作人ID
  21. CONTRACTTYPE int32 `json:"contracttype" xorm:"'CONTRACTTYPE'"` // 现货合同类型 - 1:采购 -1:销售
  22. OPERATELOGTYPEDESC string `json:"operatelogtypedesc"` // 操作流水类型名称
  23. APPLYNAME string `json:"applyname" xorm:"'APPLYNAME'"` // 操作人名称
  24. }
  25. func (r *ErmcpOPLogModel) decodeOperateLogType() {
  26. //1:点价价格 2:点价数量 3:结算量 4:其它费用 5:追加保证金 6溢短金额 7:调整金额 8:付款金额 9:收款金额 10:退款金额
  27. //11:收票金额 12:开票金额 13:提交审核(合同) 14:审核通过(合同) 15:审核拒绝(合同) 16:合同撤回 17:提交审核(计划)
  28. //18:审核通过(计划) 19:审核拒绝(计划) 20:计划撤回 21:正常完结(合同) 22:异常终止(合同) 23:退还保证金
  29. sDes := []string{"点价价格", "点价数量", "结算量", "其它费用", "追加保证金", "溢短金额", "调整金额", "付款金额", "收款金额", "退款金额",
  30. "收票金额", "开票金额", "提交审核(合同)", "审核通过(合同)", "审核拒绝(合同)", "合同撤回", "提交审核(计划)",
  31. "审核通过(计划)", "审核拒绝(计划)", "计划撤回", "正常完结(合同)", "异常终止(合同)", "退还保证金"}
  32. if r.OPERATELOGTYPE >= 1 && r.OPERATELOGTYPE <= 23 {
  33. r.OPERATELOGTYPEDESC = sDes[r.OPERATELOGTYPE-1]
  34. }
  35. }
  36. func (r *ErmcpOPLogModel) buildSql() string {
  37. str := "select BIZTYPE," +
  38. " OPERATELOGTYPE," +
  39. " RELATEDID," +
  40. " LOGVALUE," +
  41. " BEFOREVALUE," +
  42. " AFTERVALUE," +
  43. " to_char(UPDATETIME, 'yyyy-mm-dd hh24:mi:ss') UPDATETIME," +
  44. " APPLYID," +
  45. " CONTRACTTYPE," +
  46. " l.logincode APPLYNAME" +
  47. " from ermcp_contractoperatelog t" +
  48. " left join loginaccount l" +
  49. " on t.applyid = l.loginid" +
  50. " where t.relatedid = %v" +
  51. " order by t.UPDATETIME desc"
  52. return fmt.Sprintf(str, r.RELATEDID)
  53. }
  54. // GetData 从数据库中获取操作变更数据
  55. func (r *ErmcpOPLogModel) GetData() ([]ErmcpOPLogModel, error) {
  56. e := db.GetEngine()
  57. sData := make([]ErmcpOPLogModel, 0)
  58. if err := e.SQL(r.buildSql()).Find(&sData); err != nil {
  59. return nil, err
  60. }
  61. // 类型解析成中文
  62. for i := range sData {
  63. sData[i].decodeOperateLogType()
  64. }
  65. return sData, nil
  66. }