关于 mongodb 的报错: source namespace does not exist

报错说明

关于 mongodb 的报错: source namespace does not exist_第1张图片

完成任务的同步思路是:

  • 将正在使用的数据库 demo_collection 命名为 save_demo_collection
  • 将本次同步过来的的数据库从 temp_demo_collection 命名为 demo_collection
  • 将 save_demo_collection drop 掉

在 mongo shell 中的实现

但我们讲一个原本不存在的数据库重命名的时候会报错:
关于 mongodb 的报错: source namespace does not exist_第2张图片
一种解决方案是再进行 rename 之前去检查这个集合是否存在,但在之前去看下 renameCollection 的参数总是不会错的,
文档链接: https://docs.mongodb.com/manual/reference/command/renameCollection/

renameCollection
以完整的命名空间(什么是命名空间: 就是数据库名称和集合名称的组合。) database.collection 的形式来指定要修改名称的集合,只有具有 admin 权限的数据库才可以执行。

命令格式:

{ renameCollection: "", to: "", dropTarget:   writeConcern:  }

举例:

db.adminCommand( { renameCollection: "test.orders", to: "test.orders2014" } )

其中, renameCollection 是要重新命名的集合的命名空间。

to 指定了集合的新的命名空间, renameCollection 会将集合复制到新的数据库并且删除源命名空间。

dropTarget 是布尔类型可选的,默认是 false, 如果是 true, 在重命名为目标数据库之前会将同名的数据库 drop 掉。

writeConcern 意思是集群中 rename 只能针对不共享的节点,如果要 rename,这个 collection 就会被上锁,同时节点变成 unshared 的状态。

(就像是挂载硬盘,需要先进行 unmount,然后改完再挂载上去,期间硬盘是离线的)

使用 db.collection.renameCollection 会使打开的游标无效,该游标会中断当前正在返回数据的查询。

该操作可能导致的异常:
exception 10026:
Raised if the source namespace does not exist.
exception 10027:
Raised if the target namespace exists and dropTarget is either false or unspecified.
exception 15967:
Raised if the target namespace is an invalid collection name.

10026 是源命名空间不存在;

10027 是目标命名空间存在,但是并没有将 dropTarget 设置为 false 或者是未进行特殊说明。

10018 是目标命名空间无效。

现在看来问题出在 10026 上,即第一次同步的时候还没有集合,我就去做了集合重命名操作。

在 pymongo 中实现

曲线救国,不去直接判断集合是否存在,而是判断是否在数据库的集合列表中, 在的话再去 rename。 相关的代码段如下:

在这里插入图片描述

你可能感兴趣的:(mongoDB)