我在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个值的数组时,这似乎有点乏味。
为了清楚起见,我使用的是lithium PHP框架,而不仅仅是手动输入,所以我可以循环遍历一个数组来准备"细节"每个键,但我认为这不应该是必要的。关于它为什么不将值推入数组,我有什么遗漏吗?
(我的锂代码如下:)
User::update(array('$push'=>array('details'=>array('z'=>3))), array('_id'=>$id))
谢谢,
Dan
"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 } ] }
基本上,您试图推送到文档,而不是数组。