2012-03-09 118 views
4

更新數組我創建了我蒙戈文檔中的數組,所以它看起來有點像下面這樣:錯誤蒙戈

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

謝謝,

回答

4

「的信息」 是一個嵌入的文檔,而不是陣列。如果它是一個數組它是這樣的(注意[]表示數組):

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