MongoDB中的错误代码11000表示唯一键或索引遭到重复。在复制一个Mongodb集合中的值到另一个集合时,如果遇到这个错误,可以使用以下代码来处理:
db.collectionName.aggregate([
{
$group:
{
_id: "$fieldToCheck",
dups: { "$addToSet": "$_id" },
count: { "$sum": 1 }
}
},
{
$match:
{
count: { "$gt": 1 }
}
}
], { allowDiskUse: true })
.forEach(function(doc) {
doc.dups.shift();
db.collectionName.remove({ _id: { $in: doc.dups } });
});
这段代码使用了MongoDB的聚合框架,首先将要检查的字段分组,统计出现次数超过1的文档,再将剩余的文档从源集合中删除,最终避免了出现错误11000的情况。
下一篇:避免出现泄漏存储的建模