迭代mongoDB集合,为每个项执行聚合的异步任务,并且当它们全部完成时返回响应中的JSON

时间:2018-02-28 15:06:10

标签: node.js mongodb mongodb-query aggregation-framework async.js

尝试聚合MongoDB集合列表中的一些数据,并且在对所有集合进行聚合时,我想返回所有合适集合的完整聚合,其中包含名称和聚合值作为JSON对象。 node.js编程新手,因此无法解决这个琐碎的问题。任何帮助赞赏

代码:

app.get('/tester', (req, res) => {

    var AggArr = [];

    db.listCollections().toArray(function (err, collInfos) {
        async.forEachOf(collInfos, (value, key, callback) => {
            aggregate(value);
        }, err => {
            if (err)
                console.error(err.message);
            // configs is now a map of JSON data
            res.send(JSON.stringify(AggArr));
        });
    });
        function aggregate(collname) {
        if (collname.name.includes("_tps")) {
            db.collection(collname.name).aggregate([{
                        $match: {
                            $and: [{
                                    TIME: {
                                        $gte: new Date("2017-01-01T00:00:00Z")
                                    }
                                }, {
                                    TIME: {
                                        $lte: new Date("2017-12-31T23:59:59Z")
                                    }
                                }
                            ]
                        }
                    }, {
                        $group: {
                            _id: collname.name,
                            sum: {
                                $sum: "$TPS"

                            }
                        }
                    }
                ]).toArray(
                (err, result) => {
                if (err) {
                    return console.log(err)
                } else {
                    if (Object.keys(result).length === 0) {}
                    else {
                        console.log(result[0]);
                        AggArr.push(result[0]);
                    }
                }
            })
        }
        }
    })

我是Node.js编程新手,并坚持这个微不足道的问题,感谢任何帮助。

2 个答案:

答案 0 :(得分:1)

上述工作流程可以重构为以下

const pipeline = collectionName => (
    [
        { '$match': {
            'TIME': {
                '$gte': new Date("2017-01-01T00:00:00Z"), 
                '$lte': new Date("2017-12-31T23:59:59Z")
            }
        } }, 
        { '$group': {
            '_id': collectionName,
            'sum': { '$sum': "$TPS" }
        } }
    ]
);

db.listCollections().toArray((err, collInfos) => {
    const agg = collInfos
        .filter(col => col.name.includes("_tps"))
        .map(col => db.collection(col.name).aggregate(pipeline(col.name)).toArray());

    Promise.all(agg).then(data => {
        const results = data.map(d => d[0]);
        res.send(JSON.stringify(results));   
    });
});

答案 1 :(得分:1)

当您返回任何查询的回复时,它应如下所示。它会以JSON格式给出回复。

    app.get('/tester', (req, res) => {
    //DB Operaations
    if (success) {
        res.status(200).json(success);
    } else {
        res.status(500).json({
            message: 'Something went wrong'
        });
    }
});