mongo复制collection方式

1. 利用foreach方法在shell里直接运行

>mongo
>use xxx
>db.test(复制源表).find().forEach(function(x){
    db.target(目的表).insert(x);
})

 

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

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

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

3. 使用copyTo()命令

db.原始表.copyTo(新的表)
例如: 
>use YYDB
>db.XX_OLD.copyTo('XX_NEW')

你的mongo有帐号密码,就会报错: 

2021-05-27T11:35:27.762+0800 E QUERY    [thread1] Error: {
        "ok" : 0,
        "errmsg" : "not authorized on XXX to execute command { $eval: function (collName, newName) {\n        var from = db[collName];\n      ..., args: [ \"XXX\", \"XXX\" ] }",
        "code" : 13,
        "codeName" : "Unauthorized"
} :

原因: eval方法执行需要认证

解决办法:

1>  创建角色

> use admin
switched to db admin
> db.createRole(
    {
      "role": "evalRole",
      "db": "admin",
      "privileges": [
        {"resource": {"anyResource": true }, "actions": ["anyAction"] } 
       ],
      "roles": [
        {"role": "root", "db": "admin"}
      ]
    }
)

2>将角色授权给需要操作的用户

> use LOG
switched to db LOG
> db.grantRolesToUser("dbuser", [ { role: "evalRole", db: "admin" } ])
追究用户dbuser的角色 

3> 可以执行拷贝了

>use LOG
>db.auth('dbuser','密码')
>db.XXX.copyTo('YYY')

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值