蛋蛋星球RabbitMq消费项目
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.
 
 
 
 

118 lines
2.9 KiB

  1. package gim
  2. import (
  3. "applet/app/db/gim/model"
  4. "applet/app/utils"
  5. "applet/app/utils/logx"
  6. "errors"
  7. "fmt"
  8. "reflect"
  9. "xorm.io/xorm"
  10. )
  11. // BatchSelectUsers 批量查询数据 TODO::和下面的方法重复了,建议采用下面的 `UserFindByParams` 方法
  12. func BatchSelectUsers(Db *xorm.Engine, params map[string]interface{}) (*[]model.User, error) {
  13. var UserData []model.User
  14. if err := Db.In(utils.AnyToString(params["key"]), params["value"]).
  15. Find(&UserData); err != nil {
  16. return nil, logx.Warn(err)
  17. }
  18. return &UserData, nil
  19. }
  20. // UserInsert 插入单条数据
  21. func UserInsert(Db *xorm.Engine, User *model.User) (int64, error) {
  22. _, err := Db.InsertOne(User)
  23. if err != nil {
  24. return 0, err
  25. }
  26. return User.Id, nil
  27. }
  28. // BatchAddUsers 批量新增数据
  29. func BatchAddUsers(Db *xorm.Engine, UserData []*model.User) (int64, error) {
  30. affected, err := Db.Insert(UserData)
  31. if err != nil {
  32. return 0, err
  33. }
  34. return affected, nil
  35. }
  36. func GetUserCount(Db *xorm.Engine) int {
  37. var User model.User
  38. session := Db.Where("")
  39. count, err := session.Count(&User)
  40. if err != nil {
  41. return 0
  42. }
  43. return int(count)
  44. }
  45. // UserDelete 删除记录
  46. func UserDelete(Db *xorm.Engine, id interface{}) (int64, error) {
  47. if reflect.TypeOf(id).Kind() == reflect.Slice {
  48. return Db.In("id", id).Delete(model.User{})
  49. } else {
  50. return Db.Where("id = ?", id).Delete(model.User{})
  51. }
  52. }
  53. // UserUpdate 更新记录
  54. func UserUpdate(Db *xorm.Engine, id interface{}, User *model.User, forceColums ...string) (int64, error) {
  55. var (
  56. affected int64
  57. err error
  58. )
  59. if forceColums != nil {
  60. affected, err = Db.Where("id=?", id).Cols(forceColums...).Update(User)
  61. } else {
  62. affected, err = Db.Where("id=?", id).Update(User)
  63. }
  64. if err != nil {
  65. return 0, err
  66. }
  67. return affected, nil
  68. }
  69. // UserGetOneByParams 通过传入的参数查询数据(单条)
  70. func UserGetOneByParams(Db *xorm.Engine, params map[string]interface{}) (*model.User, error) {
  71. var m model.User
  72. var query = fmt.Sprintf("%s =?", params["key"])
  73. if has, err := Db.Where(query, params["value"]).Get(&m); err != nil || has == false {
  74. return nil, logx.Error(err)
  75. }
  76. return &m, nil
  77. }
  78. // UserFindByParams 通过传入的参数查询数据(多条)
  79. func UserFindByParams(Db *xorm.Engine, params map[string]interface{}) (*[]model.User, error) {
  80. var m []model.User
  81. if params["value"] == nil {
  82. return nil, errors.New("参数有误")
  83. }
  84. if params["key"] == nil {
  85. //查询全部数据
  86. err := Db.Find(&m)
  87. if err != nil {
  88. return nil, logx.Error(err)
  89. }
  90. return &m, nil
  91. } else {
  92. if reflect.TypeOf(params["value"]).Kind() == reflect.Slice {
  93. //指定In查询
  94. if err := Db.In(utils.AnyToString(params["key"]), params["value"]).Find(&m); err != nil {
  95. return nil, logx.Warn(err)
  96. }
  97. return &m, nil
  98. } else {
  99. var query = fmt.Sprintf("%s =?", params["key"])
  100. err := Db.Where(query, params["value"]).Find(&m)
  101. if err != nil {
  102. return nil, logx.Error(err)
  103. }
  104. return &m, nil
  105. }
  106. }
  107. }