ней агрегацию. Внутри нее отфильтровал данные, сгруппировал, отсортировал. Теперь нужно найти порядковый номер элемента с конкретным значением поля (оно уникальное) в этом отсортированном наборе данных. К как это сделать?
На практике: есть топ пользователей по какому-либо критерию, сформировали его в ходе агрегирования, а теперь нужно вывести номер конкретного пользователя в этом топе, который его запросил.
возможно вы ищите вот это? https://docs.mongodb.com/manual/reference/operator/aggregation/indexOfArray/#mongodb-expression-exp.-indexOfArray
Это индекс элемента в массиве, как я понимаю, применить к верхнему уровню его не получится. Представим, что агрегация на верхнем уровне выдает мне вот это: js [ {_id: 2, login: 'second_user', salesCount: 50} {_id: 3, login: 'third_user', salesCount: 35} {_id: 1, login: 'first_user', salesCount: 20} ] Каждый объект это по сути отдельный документ и в этом перечне документов я хочу найти порядковый номер пользовалетя с логином third_user.
https://stackoverflow.com/questions/42842256/how-to-get-ranking-position-of-a-mongodb-collection Но если у вас очень много таких элементов, то производительность будет печальная, если надо постоянно это делать, то заводите отдельную коллекцию и ее обновляйте по событиям или время от времени
Обсуждают сегодня