peer.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package service
  2. import (
  3. "Gwen/global"
  4. "Gwen/model"
  5. "gorm.io/gorm"
  6. )
  7. type PeerService struct {
  8. }
  9. // FindById 根据id查找
  10. func (ps *PeerService) FindById(id string) *model.Peer {
  11. p := &model.Peer{}
  12. global.DB.Where("id = ?", id).First(p)
  13. return p
  14. }
  15. func (ps *PeerService) InfoByRowId(id uint) *model.Peer {
  16. p := &model.Peer{}
  17. global.DB.Where("row_id = ?", id).First(p)
  18. return p
  19. }
  20. //// ListByUserIds 根据用户id取列表
  21. //func (ps *PeerService) ListByUserIds(userIds []uint, page, pageSize uint) (res *model.PeerList) {
  22. // res = &model.PeerList{}
  23. // res.Page = int64(page)
  24. // res.PageSize = int64(pageSize)
  25. // tx := global.DB.Model(&model.Peer{}).Preload("User")
  26. // tx.Where("user_id in (?)", userIds)
  27. // tx.Count(&res.Total)
  28. // tx.Scopes(Paginate(page, pageSize))
  29. // tx.Find(&res.Peers)
  30. // return
  31. //}
  32. func (ps *PeerService) List(page, pageSize uint, where func(tx *gorm.DB)) (res *model.PeerList) {
  33. res = &model.PeerList{}
  34. res.Page = int64(page)
  35. res.PageSize = int64(pageSize)
  36. tx := global.DB.Model(&model.Peer{})
  37. if where != nil {
  38. where(tx)
  39. }
  40. tx.Count(&res.Total)
  41. tx.Scopes(Paginate(page, pageSize))
  42. tx.Find(&res.Peers)
  43. return
  44. }
  45. // Create 创建
  46. func (ps *PeerService) Create(u *model.Peer) error {
  47. res := global.DB.Create(u).Error
  48. return res
  49. }
  50. func (ps *PeerService) Delete(u *model.Peer) error {
  51. return global.DB.Delete(u).Error
  52. }
  53. // Update 更新
  54. func (ps *PeerService) Update(u *model.Peer) error {
  55. return global.DB.Model(u).Updates(u).Error
  56. }