MongoDB 极速本地复制collection (表复制) ,Count不准确

今天为了在mongo本地备份一下数据,总结几个方法。

1,Mongo 官方只提供了远程复制clone方法,不适用本地的

db.cloneCollection('mongodb.example.net:27017','profiles',{ 'active' : true } )

2 ,遍历插入方案

db.company.find().forEach(function(x){db.company_v1.insert(x)})

3 ,批量导入方案方案 (推荐,最快)

db.company.aggregate([{$match:{}},{$out:"company_v1"}])

这里用到了mongo的 $out 操作符,获取聚合管道返回的文档并将它们写入指定的集合。
如果当前数据库不存在,则该操作将在当前数据库中创建新集合
如果指定的集合已存在,则在聚合完成后,该$out 阶段将使用新结果集合原子替换现有集合

记录问题:

MongoDB在分片后的集合上进行db.collection.count()操作时,可能会出现结果不准确的现象,需要采用聚合的方法获取集合的count结果

db.collection.aggregate(
   [
      { $group: { _id: null, count: { $sum: 1 } } }
   ]
)

不准确的原因:

  1. 操作的是分片的集合(前提);
  2. shard分片正在做块迁移,导致有重复数据出现
  3. 存在孤立文档(因为不正常关机、块迁移失败等原因导致)
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值