Mongoose - find()具有相同的多个id

时间:2016-11-21 22:31:12

标签: node.js mongodb mongoose

如果我用mongoose执行此查询;

Schema.find({
    _id: {
        $in: ['abcd1234', 'abcd1234', 'abcd1234']
    }
});

查询只会返回如下内容:

[{
    'property1': 'key1',
    'property2': 'key2'
}]

由于数组只有一个对象,显然是因为我传入了所有相同的id。但是,我实际上想要返回重复的对象。我怎么能这样做?

1 个答案:

答案 0 :(得分:4)

Mongo本身只会返回没有重复项的对象。但是,您可以构建一个具有重复项的对象数组。

例如,如果array是我的Mongo返回的对象数组 - 在这种情况下:

var array = [{
    _id: 'abcd1234',
    property1: 'key1',
    property2: 'key2'
}];

ids是您需要重复的ID列表 - 在您的情况下:

var ids = ['abcd1234', 'abcd1234', 'abcd1234'];

然后你可以这样做:

var objects = {};
array.forEach(o => objects[o._id] = o);
var dupArray = ids.map(id => objects[id]);

现在dupArray应该包含具有重复项的对象。

完整示例:

var ids = ['abcd1234', 'abcd1234', 'abcd1234'];
Schema.find({_id: {$in: ids}}, function (err, array) {
  if (err) {
    // handle error
  } else {
    var objects = {};
    array.forEach(o => objects[o._id] = o);
    var dupArray = ids.map(id => objects[id]);
    // here you have objects with duplicates in dupArray:
    console.log(dupArray);
  }
});