Найти элемент в массиве используя mongodb

Я просто хочу посчитать элемент в массиве на основе запроса. Я попробовал следующую команду, но не решил мою проблему.

Я хочу посчитать элемент, у которого TimeStamp находится между "2017-02-17T18:30:00.000Z" и "2017-02-18T18:29:59.999Z" в массиве DATA2, но он возвращает только 1.

КОД выполнен:

КОД 1

db.ABC.aggregate([{
                $match: {
                    $and: [{

                        DATA2: {
                            $exists: true
                        }

                    }, {
                        "DATA2.TimeStamp": {
                            $gte: require('../../modules/getDates').getFromDate(item),
                            $lte: require('../../modules/getDates').getToDate(item)
                        }
                    }, {
                        Client_id: "123" /*req.query.client_id*/
                    }]
                }
            }, {


                $project: {

                    DATASiz: {
                        $size: "$DATA2"
                    },
                    "has bananas": {
                        $in: ["DATA2.$.TimeStamp"]
                    }
                }
            }], function(err, result) {

                console.log(result)
                callBack();

            })

Код 2

db.abc.find({ $and:[{DATA2: {$exists: true}},{Client_id: "123"},{"DATA2": { $elemMatch: { TimeStamp: {  $gte: require('../../modules/getDates').getFromDate(item), $lte: require('../../modules/getDates').getToDate(item) } } }}]
 }, function(err, result) {

             console.log(JSON.stringify(result))
             callBack();

           })

Код 3

//db.abc.find //also tried
    db.abc.count({
                    $and: [{

                        DATA2: {
                            $exists: true
                        }

                    }, {
                        "DATA2.TimeStamp": {
                            $gte: require('../../modules/getDates').getFromDate(item),
                            $lte: require('../../modules/getDates').getToDate(item)
                        }
                    }, {
                        Client_id: "123" /*req.query.client_id*/
                    }]
                },{
                    "DATA2.$":1
                }, function(err, result) {

                    console.log(result)
                    callBack();

                })

JSON формат:

{
    "_id": {
        "$oid": "57c7404985737e2c78fde6b3"
    },
    "ABC": "1304258470",
    "Status": "Not Found",
    "DATA1": [
        {123},{123},{123}
    ],
    "Remark": "Not Found",
    "DATA2": [
        {
            "TimeStamp": "2017-02-18T09:01:43.060Z",
            "NdrStatus": "Door Locked",

        },
        {
            "TimeStamp": "2017-02-18T08:09:43.347Z",
            "NdrStatus": "HOLD",

        },
        {
            "TimeStamp": "2017-02-20T08:09:43.347Z",
            "NdrStatus": "HOLD",

        }
    ]
}

Результат: я получаю первый элемент DATA2 с использованием CODE 3, но я знаю, что согласно запросу должны возвращаться 2 элемента.

Я ожидаю 2, как в подсчете. Также используется $unwind $redact Заранее спасибо.

1 ответ

Решение

Вы можете использовать $filter а также $size операторы для этого:

var start = require('../../modules/getDates').getFromDate(item),
    end   = require('../../modules/getDates').getToDate(item);

db.ABC.aggregate([
    {
        "$match": {
            "DATA2": { "$exists": true },
            "DATA2.TimeStamp": { "$gte": start, "$lte": end },
            "Client_id": "123"
        }
    },
    {
        "$project": {
            "DATASiz": {
                "$size": {
                    "$filter": {
                        "input": "$DATA2",
                        "as": "item",
                        "cond": {
                            "$and": [
                                { "$gte": ["$$item.TimeStamp", start] },
                                { "$lte": ["$$item.TimeStamp", end] }
                            ]
                        }
                    }
                }
            }
        }
    }
], function(err, result) {
    console.log(result);
    callBack();
});
Другие вопросы по тегам