聚合返回空数组 - 猫鼬

Ste*_*fan 3 aggregate mongoose node.js mongoose-schema

我有以下两个简单的查询:

Comment.aggregate([{$match: { _id: req.params.id }}])
  .exec(function(err, result) {
    // result is empty
  });

Comment.find({ _id: req.params.id })
  .exec(function (err, result) {
    // correct result returned
  });
Run Code Online (Sandbox Code Playgroud)

我的问题是,聚合函数返回一个空数组。他们不应该返回相同的结果吗?

小智 8

是的,但您需要将 id(这是一个字符串)转换为 objectID :)

let idToSearch = mongoose.Types.ObjectId(req.params.id)
Comment.aggregate([{$match: { _id: idToSearch }}])
.exec(function(err, result) {
    // result is now correct :)
});
Run Code Online (Sandbox Code Playgroud)