MongoDB filter $ lookup документы с диапазоном дат - PullRequest
0 голосов
/ 14 сентября 2018

У меня есть запрос, который выводит как следует.

return ChallengeModel.aggregate([
    { $match: { is_processed: false,} },
    { $lookup: {
        from: 'scoreboards',
        let: { 'challengeId': '$_id' },
        pipeline: [{ $match: { $expr: { $eq: [ '$challenge_id', '$$challengeId' ]}} }],
        as: 'scoreboards'
    } }
]);

Вывод:

{
  "_id": "5b9679db0a3d61258aa3ffc3",
  "voucher_paid_by": "issuer",
  "start_date": "2018-09-03T00:00:00.000Z",
  "end_date": "2018-09-09T23:59:00.000Z",
  "accept_by_date": "2018-09-03T12:00:00.000Z",
  "scoreboards": [
    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-01T00:00:00.000Z",
      "value": 2
    },
    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-02T00:00:00.000Z",
      "value": 6
    },
    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-03T00:00:00.000Z",
      "value": 5
    },
    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-04T00:00:00.000Z",
      "value": 9
    },
    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-05T00:00:00.000Z",
      "value": 7
    },

    {
      "_id": "5b9757c68a6f1615d8e704d3",
      "user_id": "5b9667200a3d61258aa3ff9f",
      "date": "2018-09-06T00:00:00.000Z",
      "value": 1
    }
  ]
}

Я убрал challenge_id из вывода, так что вывод это только пример.

Теперь я хочу выполнить тот же запрос, когда мне нужны только данные табло, которые находятся в диапазоне start_date и end_date.

Итак, я сделал что-то подобное.

return ChallengeModel.aggregate([
    { $match: { is_processed: false,} },
    { $lookup: {
        from: 'scoreboards',
        let: { 'challengeId': '$_id', 'startDate': '$start_date', 'endDate': '$end_date' },
        pipeline: [{ $match: { 
            date: { $gte: '$$startDate', $lt: '$$endDate' },
            $expr: { $eq: [ '$challenge_id', '$$challengeId' ]}} 
        }],
        as: 'scoreboards'
    } }
]);

Но он возвращает пустоймассив табло.Я делаю это правильно?

1 Ответ

0 голосов
/ 14 сентября 2018

Вам необходимо использовать $expr с другими полями, а также $match те же поля документов .

ChallengeModel.aggregate([
  { "$match": { "is_processed": false,} },
  { "$lookup": {
    "from": "scoreboards",
    "let": { "challengeId": "$_id", "startDate": "$start_date", "endDate": "$end_date" },
    "pipeline": [
      { "$match": {
        "$expr": {
          "$and": [
            { "$eq": [ "$challenge_id", "$$challengeId" ] },
            { "$gte": [ "$date", "$$startDate" ] },
            { "$lt": [ "$date", "$$endDate" ] }
          ]
        }
      }}
    ],
    "as": "scoreboards"
  }}
])
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...