因此,正如您所注意到的,猫鼬的默认设置是,当您将数据“嵌入”这样的数组中时,您将获得
_id每个数组项的值,作为其自身的子文档属性的一部分。实际上,您可以使用此值来确定要更新的项目的索引。MongoDB的实现方式是位置
$运算符变量,该变量在数组中保持“匹配”位置:
Folder.findoneAndUpdate( { "_id": folderId, "permissions._id": permission._id }, { "$set": { "permissions.$": permission } }, function(err,doc) { });该
.findoneAndUpdate()方法将返回修改后的文档,否则,
.update()如果不需要返回文档,则可以将其用作方法。主要部分是“匹配”要更新的数组元素,并“识别”与前面提到的位置
$匹配的元素。
然后,当然,您正在使用$set
运算符,因此 只有
您指定的元素实际上是“通过电线”发送到服务器的。您可以使用“点符号”进一步说明这一点,只需指定您实际要更新的元素即可。如:
Folder.findoneAndUpdate( { "_id": folderId, "permissions._id": permission._id }, { "$set": { "permissions.$.role": permission.role } }, function(err,doc) { });因此,这就是MongoDB提供的灵活性,您可以在其中真正地“定向”实际更新文档的方式。
但是,这样做是“绕过”您可能在“猫鼬”模式中构建的任何逻辑,例如“验证”或其他“预保存钩子”。这是因为“最佳”方式是MongoDB的“功能”及其设计方式。猫鼬本身试图成为这种逻辑的“便利”包装。但是,如果您准备自己进行一些控制,则可以以最佳方式进行更新。
因此,在可能的情况下,请保持数据“嵌入”并且不要使用引用的模型。它允许您在不需要担心并发性的简单更新中对“父”和“子”项进行原子更新。可能是您应该首先选择MongoDB的原因之一。



