gpt4 book ai didi

php - 在 Mongo 中更新数组时出错

转载 作者:可可西里 更新时间:2023-11-01 09:13:19 26 4
gpt4 key购买 nike

我在我的 mongo 文档中创建了一个数组,所以它看起来有点像下面这样:

{ "_id" : ObjectId("4f59e19d0b7aab2903000004"), 
"details" : { x:1, y:2 }
}

然后我尝试将一个新值推送到数组,执行以下操作:

db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{$push: {"details": {"z":3}}});

但是我得到了错误:

Cannot apply $push/$pushAll modifier to non-array

似乎我实际上能够将信息添加到数组的唯一方法是使用点符号来添加它,例如

db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{"details.z": 3});

这似乎可行,但是当我有大约 30 个值的数组时,它似乎有点乏味。

为清楚起见,我使用的是锂 PHP 框架,而不仅仅是手动输入这些内容,因此我可以循环遍历数组以在“详细信息”前面添加。每个键,但我认为这不是必需的。关于为什么它不会将值插入数组,我是否遗漏了什么?

(我的锂代码如下:)

User::update(array('$push'=>array('details'=>array('z'=>3))), array('_id'=>$id))

谢谢,

最佳答案

"details"是嵌入文档,不是数组。如果它是一个数组,它看起来像这样(注意 [] 表示一个数组):

{ "_id" : ObjectId("4f59f0531ae8f3b5f92246fe"), 
"details" : [ { "x" : 1 }, { "y" : 2 } ] }

如果你然后执行 $push:

db.users.update({"_id" : ObjectId("4f59f0531ae8f3b5f92246fe")}, 
{$push : {"details": {"z":3}}})

你得到了预期的结果:

db.users.find({"_id" : ObjectId("4f59f0531ae8f3b5f92246fe")})

{ "_id" : ObjectId("4f59f0531ae8f3b5f92246fe"),
"details" : [ { "x" : 1 }, { "y" : 2 }, { "z" : 3 } ] }

基本上,您正在尝试推送到文档,而不是数组。

关于php - 在 Mongo 中更新数组时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9633127/

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