Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 更新Mongo中的数组时出错_Php_Mongodb_Lithium - Fatal编程技术网

Php 更新Mongo中的数组时出错

Php 更新Mongo中的数组时出错,php,mongodb,lithium,Php,Mongodb,Lithium,我在我的mongo文档中创建了一个数组,因此它看起来有点像以下内容: { "_id" : ObjectId("4f59e19d0b7aab2903000004"), "details" : { x:1, y:2 } } 然后,我尝试将新值推送到数组中,执行以下操作: db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{$push: {"details": {"z":3}}}); 但是我得到了一个错误: Cann

我在我的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个值的数组时,它似乎有点乏味

为了清楚起见,我使用的是Limition PHP框架,而不仅仅是手动输入,这样我就可以通过一个数组对每个键预先添加“细节”,但我认为这不必要。是否有什么我不知道的,为什么它不能将值推送到数组中

(我的锂代码如下:)

谢谢

Dan“详细信息”是一个嵌入式文档,而不是数组。如果它是一个数组,它将如下所示(注意[]表示数组):

如果然后执行$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 } ] }

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

这是有道理的——这似乎是Limition框架创建数组(或者更确切地说是文档)的方式。我正在使用User::create(数组('details'=>array('x'=>1,'y'=>2));我原以为可以,但显然不行!
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 } ] }