У меня есть такая структура документа:
{
...,
insertionDate: 'someDate',
product: 'cool jacket',
color: 'red',
store: 'north store',
}
Дело в том, что в этой коллекции хранятся все изменения, которые когда-либо были в продукте. На данный момент у меня есть следующий код для получения всех продуктов в одном магазине с одним цветом из ранее определенного набора.
const colors = ['red', 'blue', 'orange'];
collection.find({$and: [{store: store)}, {color: {$in: colors}}]});
Проблема в том, что я получаю все исторические данные, например, я могу получить «крутую куртку» каждого цвета 4 раза, потому что она появляется в базе данных несколько раз с разной вставкой.
Как получить последнюю дату вставки каждого продукта?
3 ответа
Вы можете использовать collection.find({$and: [{store: store)}, {color: {$in: colors}}]}).sort(insertionDate: -1)
, чтобы отсортировать их в соответствии с последней вставленной датой.
Вы можете добиться этого, используя агрегированный запрос с тремя конвейерами.
$match
, чтобы соответствовать нужному магазину и цветам.Используйте
$sort
для сортировки по порядку описанияinsertionDate
.$group
для группировки по названию или идентификатору продукта. При группировке аккумулятор$first
поможет получить последний вставленный продукт.
Вот проверенный код:
await Collection.aggregate([
{
$match: {
color: { $in: colors }
}
},
{ $sort: { insersionDate: -1 } },
{ $group: { _id: '$product', doc: { $first: '$$ROOT' } } }
]);
Похожие вопросы
Новые вопросы
javascript
По вопросам программирования на ECMAScript (JavaScript / JS) и его различных диалектах / реализациях (кроме ActionScript). Включите все соответствующие теги в свой вопрос; например, [node.js], [jquery], [json] и т. д.