SJA APS后端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

177 lines
4.5 KiB

  1. package db
  2. import (
  3. "errors"
  4. "github.com/go-xorm/xorm"
  5. "leit.com/leit_seat_aps/common"
  6. "xorm.io/core"
  7. )
  8. //拣料单
  9. type Pln_pickorder struct {
  10. Finr int `xorm:"pk" json:"pln_pickorder.finr"`
  11. Pickorderid string `xorm:"pk" json:"pln_pickorder.pickorderid"`
  12. Picktemplateid string `json:"pln_pickorder.picktemplateid"`
  13. Status int `json:"pln_pickorder.status"`
  14. Orderinfo string `json:"pln_pickorder.orderinfo"`
  15. Worklineid string `json:"pln_pickorder.worklineid"`
  16. Printerid string `json:"pln_pickorder.printerid"`
  17. Planqty int `json:"pln_pickorder.planqty"`
  18. Fillqty int `json:"pln_pickorder.fillqty"`
  19. Actqty int `json:"pln_pickorder.actqty"`
  20. Picker string `json:"pln_pickorder.picker"`
  21. Lastmodif string `json:"pln_pickorder.lastmodif"`
  22. Lastuser string `json:"pln_pickorder.lastuser"`
  23. Credatuz string `json:"pln_pickorder.credatuz"`
  24. Itemlst []Pln_pickorder_itemlst `xorm:"-"`
  25. }
  26. func (t *Pln_pickorder) Clipped() {
  27. common.TrimStruct(t, *t)
  28. }
  29. func (t *Pln_pickorder) TableName() string {
  30. return "pln_pickorder"
  31. }
  32. //增
  33. func (t *Pln_pickorder) Add() error {
  34. e := G_DbEngine
  35. pikotab := new(Pln_pickorder)
  36. affw, err := e.Table("pln_pickorder").ID(core.PK{G_FINR, t.Pickorderid}).Count(pikotab)
  37. if err != nil {
  38. return err
  39. }
  40. if affw > 0 {
  41. return errors.New("数据已经存在!")
  42. }
  43. _, err = e.Table("pln_pickorder").Insert(t)
  44. if err != nil {
  45. return err
  46. }
  47. return nil
  48. }
  49. //增
  50. func (t *Pln_pickorder) Insert(session *xorm.Session) error {
  51. pikotab := new(Pln_pickorder)
  52. affw, err := session.Table("pln_pickorder").ID(core.PK{G_FINR, t.Pickorderid}).Count(pikotab)
  53. if err != nil {
  54. return err
  55. }
  56. if affw > 0 {
  57. return errors.New("数据已经存在!")
  58. }
  59. _, err = session.Table("pln_pickorder").Insert(t)
  60. if err != nil {
  61. return err
  62. }
  63. return nil
  64. }
  65. //删
  66. func (t *Pln_pickorder) Del() bool {
  67. e := G_DbEngine
  68. _, err := e.ID(core.PK{G_FINR, t.Pickorderid}).Delete(&Pln_pickorder{})
  69. if err != nil {
  70. return false
  71. }
  72. return true
  73. }
  74. //改
  75. func (t *Pln_pickorder) Update() bool {
  76. e := G_DbEngine
  77. _, err := e.ID(core.PK{G_FINR, t.Pickorderid}).Update(t)
  78. if err != nil {
  79. return false
  80. }
  81. return true
  82. }
  83. //更新指定字段
  84. func (t *Pln_pickorder) UpdateFields(session *xorm.Session, fields string) (err error) {
  85. if _, err = session.ID(core.PK{G_FINR, t.Pickorderid}).Cols(fields).Update(t); err != nil {
  86. return
  87. }
  88. return
  89. }
  90. //查
  91. func (t *Pln_pickorder) SelectOne() (data Pln_pickorder, err error) {
  92. var i int
  93. e := G_DbEngine
  94. _, err = e.ID(core.PK{G_FINR, t.Pickorderid}).Get(&data)
  95. if err != nil {
  96. return data, err
  97. }
  98. data.Clipped()
  99. // 获取分配的拣料项列表
  100. if err = e.Where("finr = ? and pickorderid = ?", G_FINR, t.Pickorderid).OrderBy("pos").Find(&data.Itemlst); err != nil {
  101. return
  102. }
  103. for i, _ = range data.Itemlst {
  104. data.Itemlst[i].Clipped()
  105. }
  106. return data, nil
  107. }
  108. //查
  109. func (t *Pln_pickorder) SelectOneBySession(session *xorm.Session) (data Pln_pickorder, err error) {
  110. var i int
  111. _, err = session.ID(core.PK{G_FINR, t.Pickorderid}).Get(&data)
  112. if err != nil {
  113. return data, err
  114. }
  115. data.Clipped()
  116. // 获取分配的拣料项列表
  117. if err = session.Where("finr = ? and pickorderid = ?", G_FINR, t.Pickorderid).OrderBy("pos").Find(&data.Itemlst); err != nil {
  118. return
  119. }
  120. for i, _ = range data.Itemlst {
  121. data.Itemlst[i].Clipped()
  122. }
  123. return data, nil
  124. }
  125. //
  126. func (t *Pln_pickorder) GetOpenOrdersForTemplateBySession(session *xorm.Session, picktmpid string) (exist bool, datalst []Pln_pickorder, err error) {
  127. var (
  128. itemtablst []Pln_pickorder_itemlst
  129. i, j int
  130. )
  131. if err = session.Where("finr = ? and picktemplateid = ? and status < ? ",
  132. G_FINR, picktmpid, common.PKO_STATUS_RELEASED).Asc("credatuz").Find(&datalst);
  133. err != nil {
  134. return
  135. }
  136. if len(datalst) <= 0 {
  137. exist = false
  138. return
  139. }
  140. // 获取拣料单子项数据
  141. for i = 0; i < len(datalst); i++ {
  142. datalst[i].Clipped()
  143. // 获取分配的拣料项列表
  144. itemtablst = []Pln_pickorder_itemlst{}
  145. if err = session.Where("finr = ? and pickorderid = ?", G_FINR, datalst[i].Pickorderid).OrderBy("pos").Find(&itemtablst); err != nil {
  146. return
  147. }
  148. for j, _ = range itemtablst {
  149. itemtablst[j].Clipped()
  150. }
  151. datalst[i].Itemlst = itemtablst
  152. }
  153. exist = true
  154. return
  155. }