gpt4 book ai didi

mongodb - 将数据从一个集合复制到另一个集合时,MongoDB 中的 _id 字段是否会发生变化?

转载 作者:行者123 更新时间:2023-12-03 23:31:55 27 4
gpt4 key购买 nike

我们计划使用 MongoDB _id 作为我们提供给客户端的 key 。因此,要求是如果我们需要将数据从一个集合移动到另一个集合,则该键不应更改。将使用 db.copyDatabase() 或 mongoimport 执行复制。

将数据从一个集合复制到另一个集合的方法之一是遍历第一个集合 (C1) 中的文档并将这些文档插入第二个集合 (C2) 中。在这种情况下,_id 应该保持不变(在 C2 中),因为它会出现在插入的(C1 的)文档中(与我们自己提供 _id 的情况相同)。

但是,如果有其他复制文档的方式,_id 可能会更改,因为它取决于:

(1) UNIX 时间戳
(2) 机器标识符
(3) 进程ID

(**这只应该在 MongoDB 在复制时从 C1 中的文档中删除 _id 并在插入 C2 时重新生成它们时发生?)

无论目标集合的位置如何,我们都希望 _id 值相同:
(1)在同一个数据库内
(2)不同的数据库——同一台机器
(3)不同的数据库-不同的机器)

谢谢

最佳答案

不,_id 号码不会改变。

当文档 生成一个新的 ObjectId没有 _id 字段被插入到数据库中。当您插入一个已经有 _id 字段的文档时,MongoDB 不会触及它。

时间戳、机器标识符和进程 ID 是指生成 ObjectID 的那些。这可以是数据库服务器,但也可以由应用服务器上的 MongoDB 驱动程序生成。在这种情况下,MongoDB 不会自行更改它。

顺便说一句:_id 可以是自动生成的 ObjectId,但不是必须的。您还可以使用任何其他值作为 _id,只要您能保证它是唯一的。因此,当您的数据已经具有自然键时,您可以在需要时将其用作 _id。

关于mongodb - 将数据从一个集合复制到另一个集合时,MongoDB 中的 _id 字段是否会发生变化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24741667/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com