user.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package dao
  2. import (
  3. "errors"
  4. "fmt"
  5. "github.com/RaymondCode/simple-demo/entities"
  6. "github.com/RaymondCode/simple-demo/util"
  7. "gorm.io/gorm"
  8. "strconv"
  9. "sync"
  10. )
  11. type UserDao struct{}
  12. var (
  13. userDao *UserDao
  14. userOnce sync.Once
  15. )
  16. func NewUserDaoInstance() *UserDao {
  17. userOnce.Do(func() {
  18. userDao = &UserDao{}
  19. })
  20. return userDao
  21. }
  22. func GetUserByIdAndPassword(userId string, password string) (*entities.User, error) {
  23. //检查用户名是否存在
  24. var user entities.User
  25. result := Db.Table("user").Where("user_id = ?", userId).Limit(1).Find(&user)
  26. if result.RowsAffected == 0 {
  27. err := errors.New("username does not exist")
  28. return nil, err
  29. }
  30. //检查密码是否正确
  31. if util.GetMd5Val(password) != user.Password {
  32. err := errors.New("wrong password")
  33. return nil, err
  34. }
  35. return &user, nil
  36. }
  37. func GetUserById(tokenString string) entities.User {
  38. var res entities.User
  39. Db.Table("user").Where("user_id = ?", tokenString).Limit(1).Find(&res)
  40. fmt.Printf("%+v\n", res)
  41. return res
  42. }
  43. func GetUserByIdInt64(userId int64) entities.User {
  44. var res entities.User
  45. id := strconv.FormatInt(userId, 10)
  46. Db.Table("user").Where("id = ?", id).Limit(1).Find(&res)
  47. return res
  48. }
  49. func GetIdByUserId(userid string) string {
  50. var res entities.User
  51. Db.Table("user").Where("user_id = ?", userid).Limit(1).Find(&res)
  52. return strconv.FormatInt(res.Id, 10)
  53. }
  54. func GetUserByUserIdInt64(userId int64) entities.User {
  55. var res entities.User
  56. id := strconv.FormatInt(userId, 10)
  57. Db.Table("user").Where("user_id = ?", id).Limit(1).Find(&res)
  58. return res
  59. }
  60. func AddNewUser(user2 entities.User) error {
  61. err := Db.Transaction(func(tx *gorm.DB) error {
  62. // 在事务中执行一些 db 操作(从这里开始,您应该使用 'tx' 而不是 'db')
  63. if err := tx.Table("user").Create(user2).Error; err != nil {
  64. // 返回任何错误都会回滚事务
  65. fmt.Println("create new user error")
  66. return err
  67. }
  68. // 返回 nil 提交事务
  69. return nil
  70. })
  71. return err
  72. }
  73. func GetUserListByIdArray(list []int64) []entities.User {
  74. var temp []entities.User
  75. Db.Table("user").Where("id In ?", list).Debug().Find(&temp)
  76. return temp
  77. }