如果我用mongoose执行此查询;
Schema.find({
_id: {
$in: ['abcd1234', 'abcd1234', 'abcd1234']
}
});
查询只会返回如下内容:
[{
'property1': 'key1',
'property2': 'key2'
}]
由于数组只有一个对象,显然是因为我传入了所有相同的id。但是,我实际上想要返回重复的对象。我怎么能这样做?
答案 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);
}
});