• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Mongoose Paginacja Subdokomentu

VPS Starter Arubacloud
0 głosów
102 wizyt
pytanie zadane 23 stycznia 2020 w JavaScript przez CapTor Nowicjusz (240 p.)

Hej,

Trafiłem na dość ciekawy problem z którym internet nie może sobie poradzić, może jest tu jakaś osoba która bawiła się z mongodb i znalazła rozwiązanie.

Problem polega na tym, że chcę zrobić paginację powiadomień użytkownika jednak opcje takie jak limit oraz skip nie działają z populate. Myślałem nad przebudową schematu aby wszystkie powiadomienia trzymać w oddzielnym dokumencie ale postanowiłem, że zrobię to w ostateczności.

 

Tak wygląda subdocument w dokumencie użytkownika 

friendRequest:[{
    requestUser:{
    type: mongoose.Schema.Types.ObjectId,
    ref: "Users"
    },
    read:{
        type:Boolean,
        default:false
    }
}],

A tak kod zwracający dane z bazy 

const user = await User.findById(req.user.id).select('.friendRequest').populate({
        path: 'friendRequest.requestUser', 
        options: {
          skip: 5,
          limit : 10
      },
        select:['username', 'avatarUrl'],
        model:'Users',
      })

Zaobserwowałem, że limit w ogóle nie działa natomiast użycie skip w options powoduje że zwracane są same wartości null

1 odpowiedź

0 głosów
odpowiedź 23 stycznia 2020 przez CapTor Nowicjusz (240 p.)

Udało mi się znaleźć rozwiązanie tylko mam pytanie do ekspertów czy jest to optymalne rozwiązanie?

const pagination = req.query.pagination ? parseInt(req.query.pagination): 1;

const user = await User.findById(req.user.id).select('.friendRequest').where('friendRequest').slice(pagination).populate({
        path: 'friendRequest.requestUser', 
        options: {
      },
        select:['username', 'avatarUrl'],
        model:'Users',
      })

 

Podobne pytania

+1 głos
0 odpowiedzi 83 wizyt
pytanie zadane 20 września 2020 w JavaScript przez poldeeek Mądrala (5,980 p.)
0 głosów
0 odpowiedzi 135 wizyt
pytanie zadane 15 sierpnia 2020 w JavaScript przez Darth_Sith Początkujący (310 p.)
0 głosów
0 odpowiedzi 523 wizyt

92,832 zapytań

141,777 odpowiedzi

320,824 komentarzy

62,163 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...