gpt4 book ai didi

mongodb - 关于 _id 和嵌套对象

转载 作者:可可西里 更新时间:2023-11-01 10:35:15 27 4
gpt4 key购买 nike

如果有人能回答我的新手 MongoDB 问题,我将不胜感激。

  1. 如果用户分配的 _id 字段不是唯一的,会有什么后果在数据库或集合中?在什么范围内唯一性是真正必要的(嵌套对象的范围是什么)?

  2. 是否可以更改(替换)集合中整个文档的 _id(及其类型)?

  3. 当我将嵌套对象存储为 json 对象(见下文 - A)或存储为具有 _id (B) 的嵌入式文档时,嵌套对象之间有什么区别(在由 DB 引擎处理时)?

    A) {book: _id:.. chapters[{json object has not _id},{}]}

    B) {book: _id:.. chapters[{_id:... },{}]}

    区别只是存在 _id 和索引还是更深层次的东西?

  4. 如何将“仅 json 对象”(不带 _id)转换为带 _id 的嵌入式文档?

最佳答案

What will be consequences if user assigned _id field won't be unique in DB or collection? In what scope uniqueness is really necessary (and what is the scope for nested objects)?

唯一性在任何数据集中都太重要了,因为您需要一种方法来通过某种身份来识别您的数据。唯一 ID 是关键。

当您定义唯一索引时,这一点非常重要。当您尝试在唯一索引中添加重复键时,它会被搞砸。

Is it possible to change (replace) _id (and its type) for the whole documents in the collection?

不,这不可能以直接的方式进行,您需要将文档数据复制到临时集合,然后使用新 ID 将它们重新插入到原始集合中。

what is the difference (in handling by DB engine) between nested objects when I store just as json objects (see below - A) or as embedded documents with _id (B)?

嵌入式对象是 mongodb 原生支持的对象,引用对象将由您的代码手动处理,主要由 ODM(如 ruby​​ Mongoid)

既然你问了区别,嵌入式文档被视为文档中的另一个字段,所以你可以查询它,你可以索引它并将作为文档的一部分返回。

但是引用文档完全是一个单独的文档。您不能直接从父文档和索引中查询它。相反,您必须编写应用程序逻辑来存储 ID 并从应用程序中手动查询它们。

How can I convert "just json objects"(without _id) to embedded documents with _id?

您的假设是错误的。嵌入式文档确实有 ID。创建时会自动生成。

编辑:

我的假设在这方面是错误的。 Mongodb 不会自动生成嵌入文档的 ID。但是一些 ODM(例如 Mongoid)也会为嵌入式文档生成 ID。

关于mongodb - 关于 _id 和嵌套对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8057355/

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