У меня есть такая структура документа:

{
 ...,
insertionDate: 'someDate',
product: 'cool jacket',
color: 'red',
store: 'north store',
}

Дело в том, что в этой коллекции хранятся все изменения, которые когда-либо были в продукте. На данный момент у меня есть следующий код для получения всех продуктов в одном магазине с одним цветом из ранее определенного набора.

const colors = ['red', 'blue', 'orange'];    
collection.find({$and: [{store: store)}, {color: {$in: colors}}]});

Проблема в том, что я получаю все исторические данные, например, я могу получить «крутую куртку» каждого цвета 4 раза, потому что она появляется в базе данных несколько раз с разной вставкой.

Как получить последнюю дату вставки каждого продукта?

0
lololololololol 3 Фев 2022 в 21:35

3 ответа

Вы можете использовать collection.find({$and: [{store: store)}, {color: {$in: colors}}]}).sort(insertionDate: -1), чтобы отсортировать их в соответствии с последней вставленной датой.

0
Abu Sayad Hussain 3 Фев 2022 в 21:47

Вы можете добиться этого, используя агрегированный запрос с тремя конвейерами.

  1. $match, чтобы соответствовать нужному магазину и цветам.

  2. Используйте $sort для сортировки по порядку описания insertionDate.

  3. $group для группировки по названию или идентификатору продукта. При группировке аккумулятор $first поможет получить последний вставленный продукт.

0
Gibbs 3 Фев 2022 в 23:03

Вот проверенный код:

await Collection.aggregate([
    {
      $match: {
        color: { $in: colors }
      }
    },
    { $sort: { insersionDate: -1 } },
    { $group: { _id: '$product', doc: { $first: '$$ROOT' } } }
  ]);
0
Zohar 3 Фев 2022 в 23:49