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.

151 lines
5.0 KiB

  1. package db
  2. import (
  3. "errors"
  4. "fmt"
  5. "leit.com/leit_seat_aps/common"
  6. conf "leit.com/leit_seat_aps/config"
  7. "leit.com/leit_seat_aps/glog"
  8. "strings"
  9. "xorm.io/core"
  10. )
  11. /******备注:打印服务数据放到从库***************/
  12. type Printertab struct {
  13. Finr int `xorm:"not null pk comment('车间编号') INT(0)" json:"printertab-finr"`
  14. Printerid string `xorm:"not null pk comment('打印机id') VARCHAR(18)" json:"printertab-printerid"`
  15. Descr string `xorm:"not null comment('描述') VARCHAR(30)" json:"printertab-descr"`
  16. Printertype string `xorm:"not null comment('打印机类型') VARCHAR(1)" json:"printertab-printertype"`
  17. Printername string `xorm:"not null comment('打印机名称') VARCHAR(100)" json:"printertab-printername"`
  18. Ipaddress string `xorm:"not null comment('IP地址') VARCHAR(15)" json:"printertab-ipaddress"`
  19. Active int `xorm:"not null comment('激活') INT(0)" json:"printertab-active"`
  20. Printerspec string `xorm:"not null comment('打印机规格') VARCHAR(30)" json:"printertab-printerspec"`
  21. Pagesize string `xorm:"not null comment('页面尺寸') VARCHAR(18)" json:"printertab-pagesize"`
  22. Port int `xorm:"not null comment('端口号') INT(0)" json:"printertab-port"`
  23. Printinterval int `xorm:"not null comment('打印机间隔时间(秒)') INT(0)" json:"printertab-printinterval"`
  24. Lastmodif string `xorm:"not null comment('上一次更改日期') VARCHAR(14)" json:"printertab-lastmodif"`
  25. Lastuser string `xorm:"not null comment('最后编辑人员') VARCHAR(20)" json:"printertab-lastuser"`
  26. Credatuz string `xorm:"not null comment('创建时间') VARCHAR(14)" json:"printertab-credatuz"`
  27. }
  28. func (t *Printertab) TableName() string {
  29. return "printertab"
  30. }
  31. // 清除string字段的右侧空格
  32. func (t *Printertab) Clipped() {
  33. common.TrimStruct(t, *t)
  34. }
  35. //增
  36. func (t *Printertab) Add() error {
  37. e := G_DbEngine
  38. countrole := new(Printertab)
  39. affw, err := e.Table("printertab").ID(core.PK{t.Finr, t.Printerid}).Count(countrole)
  40. if err != nil {
  41. return err
  42. }
  43. if affw > 0 {
  44. return errors.New("数据已经存在!")
  45. }
  46. _, err = e.Table("printertab").Insert(t)
  47. if err != nil {
  48. fmt.Printf("err is :%v",err)
  49. return err
  50. }
  51. return nil
  52. }
  53. //删
  54. func (t *Printertab) Del() bool {
  55. e := G_DbEngine
  56. _, err := e.ID(core.PK{t.Finr, t.Printerid}).Delete(&Printertab{})
  57. if err != nil {
  58. return false
  59. }
  60. return true
  61. }
  62. //改
  63. func (t *Printertab) Update() bool {
  64. e := G_DbEngine
  65. _, err := e.ID(core.PK{t.Finr, t.Printerid}).Cols("finr","printerid","descr","printertype","printername","ipaddress","active","printerspec","pagesize","port","printinterval","lastmodif","lastuser","credatuz").Update(t)
  66. if err != nil {
  67. return false
  68. }
  69. return true
  70. }
  71. //查
  72. func (t *Printertab) SelectOne() (Printertab, error) {
  73. e := G_DbEngine
  74. var data Printertab
  75. _, err := e.ID(core.PK{t.Finr, t.Printerid}).Get(&data)
  76. if err != nil {
  77. return data, err
  78. }
  79. return data, nil
  80. }
  81. //分页
  82. func (t *Printertab) GetPage(pageSize int, pageIndex int) ([]Printertab, int, error) {
  83. data := make([]Printertab, 0)
  84. e := G_DbEngine
  85. table := e.Table("printertab").Where("finr = ? ", t.Finr)
  86. where := "where finr = " + "'" + common.ValueToString(t.Finr, "") + "'"
  87. if !common.ValueIsEmpty(t.Printerid) {
  88. table = table.And("printerid = ?", t.Printerid)
  89. where += " and printerid = " + "'" + t.Printerid + "'"
  90. }
  91. Offset := (pageIndex - 1) * pageSize
  92. err := e.SQL("SELECT TOP " + common.ValueToString(pageSize, "") + " printertab.* FROM printertab " + where + " AND (convert(varchar(10),finr)+convert(varchar(40),printerid) NOT IN (SELECT TOP " + common.ValueToString(Offset, "") + " convert(varchar(10),finr)+convert(varchar(40),printerid) FROM printertab " + where + " ORDER BY credatuz DESC)) ORDER BY credatuz DESC").Find(&data)
  93. pcount := new(Printertab)
  94. count, err := table.Count(pcount)
  95. if err != nil {
  96. return data, 0, err
  97. }
  98. for k, _ := range data {
  99. data[k].Clipped()
  100. }
  101. return data, int(count), nil
  102. }
  103. // 获取所有激活的打印机对象列表
  104. func (t *Printertab) GetPrinterList(conf *conf.EnvConfig) ( []Printertab, error ) {
  105. var (
  106. printertablist []Printertab
  107. pt []string
  108. )
  109. e := G_DbEngine
  110. pt = strings.Split(conf.PrinterType, ",")
  111. err := e.Where("finr = ? and active = ?", conf.Finr, 1).In("printertype",pt).Find(&printertablist)
  112. if err != nil{
  113. glog.Infoln("failed to query printertab for type: %s due to: %v", pt, err)
  114. return nil, err
  115. }
  116. for i := range printertablist {
  117. printertablist[i].Clipped()
  118. }
  119. return printertablist, nil
  120. }
  121. // 获取打印机ID列表
  122. func (t *Printertab) GetPrinterIdList(conf *conf.EnvConfig) ( []string, error ) {
  123. var (
  124. printertablist []Printertab
  125. prnlist, pt []string
  126. )
  127. e := G_DbEngine
  128. pt = strings.Split(conf.PrinterType, ",")
  129. err := e.Where("finr = ? and active = ?", conf.Finr, 1).In("printertype",pt).Find(&printertablist)
  130. if err != nil{
  131. glog.Infoln("failed to query printertab for type: due to:", pt, err)
  132. return nil, err
  133. }
  134. for i := range printertablist {
  135. prnlist = append(prnlist, strings.TrimSpace( printertablist[i].Printerid ))
  136. }
  137. return prnlist, nil
  138. }