我正在将mongoDB与mongojs作为驱动程序一起运行node.js.
我有以下问题,

我尝试使用_id数组查询业务集合,如果尝试按以下方式动态构建查询,则会得到长度为0的数组,这是错误的。

 myFavoriteBusinessArray.forEach(function (iValue, j) {
            var temp = 'mongojs.ObjectId("' + iValue + '")';
            objectIdArray.push(temp);
        });
        var queryObject = {
            _id: {
                $in: objectIdArray
            }
        };
 db1.db.business.find(queryObject,
            function (err, business) {
                if (err) res.json(err);
                res.json(business);
            });
    }
    else {
        res.json({"login": "failed"});
    }


如果我尝试以下操作,那么我将得到正确的3阵列。

db1.db.business.find({_id: { $in: [ mongojs.ObjectId("534fabb10648cd1c1b000002"), mongojs.ObjectId("52d664c15186ad103c000001"), mongojs.ObjectId("534ee1b4b51682bc30000002") ] }},
            function (err, business) {
                if (err) res.json(err);
                res.json(business);
            });


有人可以指出我要去哪里了吗?提前谢谢了。

问候,
赤丹

最佳答案

您应该替换:

var temp = 'mongojs.ObjectId("' + iValue + '")';


通过:

var temp = mongojs.ObjectId(iValue);

10-04 21:30