一物一码
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.
 
 
 
 
 
 

84 lines
1.9 KiB

  1. package db
  2. import (
  3. "applet/app/db/model"
  4. "applet/app/enum"
  5. "applet/app/utils/logx"
  6. "xorm.io/xorm"
  7. )
  8. type QrcodeDb struct {
  9. Db *xorm.Engine `json:"db"`
  10. }
  11. func (qrcodeDb *QrcodeDb) Set() { // set方法
  12. qrcodeDb.Db = Db
  13. }
  14. func (qrcodeDb *QrcodeDb) GetQrcode(id int) (m *model.Qrcode, err error) {
  15. m = new(model.Qrcode)
  16. has, err := qrcodeDb.Db.Where("id =?", id).Get(m)
  17. if err != nil {
  18. return nil, logx.Error(err)
  19. }
  20. if has == false {
  21. return nil, nil
  22. }
  23. return m, nil
  24. }
  25. func (qrcodeDb *QrcodeDb) GetQrcodeByIndex(index string) (m *model.Qrcode, err error) {
  26. m = new(model.Qrcode)
  27. has, err := qrcodeDb.Db.Where("index =?", index).Get(m)
  28. if err != nil {
  29. return nil, logx.Error(err)
  30. }
  31. if has == false {
  32. return nil, nil
  33. }
  34. return m, nil
  35. }
  36. func (qrcodeDb *QrcodeDb) GetQrcodeForAllowUse() (m *model.Qrcode, err error) {
  37. m = new(model.Qrcode)
  38. has, err := qrcodeDb.Db.Where("state =?", enum.QrcodeSateAllowUse).Get(m)
  39. if err != nil {
  40. return nil, logx.Error(err)
  41. }
  42. if has == false {
  43. return nil, nil
  44. }
  45. return m, nil
  46. }
  47. func (qrcodeDb *QrcodeDb) FindQrcodeForAllowUse() (m []*model.Qrcode, total int64, err error) {
  48. total, err = qrcodeDb.Db.Where("state =?", enum.QrcodeSateAllowUse).FindAndCount(&m)
  49. return
  50. }
  51. func (qrcodeDb *QrcodeDb) BatchAddQrcode(data []*model.Qrcode) (int64, error) {
  52. affected, err := qrcodeDb.Db.Insert(data)
  53. if err != nil {
  54. return 0, err
  55. }
  56. return affected, nil
  57. }
  58. func (qrcodeDb *QrcodeDb) BatchUpdateQrcodeBySession(session *xorm.Session, ids []int, state int32) (int64, error) {
  59. m := new(model.Qrcode)
  60. m.State = state
  61. affected, err := session.In("id", ids).Cols("state").Update(m)
  62. if err != nil {
  63. return 0, err
  64. }
  65. return affected, nil
  66. }
  67. func (qrcodeDb *QrcodeDb) BatchUpdateQrcode(m *model.Qrcode, columns ...string) (int64, error) {
  68. affected, err := qrcodeDb.Db.Where("id =?", m.Id).Cols(columns...).Update(m)
  69. if err != nil {
  70. return 0, err
  71. }
  72. return affected, nil
  73. }