错误蒙戈

问题描述:

更新数组我创建了我蒙戈文档中的数组,所以它看起来有点像下面这样:错误蒙戈

{ "_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)) 

谢谢,

“的信息” 是一个嵌入的文档,而不是阵列。如果它是一个数组它是这样的(注意[]表示数组):

{ "_id" : ObjectId("4f59f0531ae8f3b5f92246fe"), 
     "details" : [ { "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 } ] } 

基本上你试图推送到一个文件,而不是一个数组。

+0

这很有道理 - 似乎是锂框架创建数组(或文档)的方式。我使用User :: create(array('details'=> array('x'=> 1,'y'=> 2)));我认为会这样做,但显然不是! – Dan 2012-03-11 15:53:26