[mongodb]使用mongodb中數組元素的下標來做更新(update)多維陣列

來源:互聯網
上載者:User

mongodb的DBObject支援儲存多維陣列,在增加元素時使用"$push"操作符,在刪除元素時使用"$pull".

但是在做更新時問題就來了,mongodb首先支援使用"$"來定位元組中的某個元素,例如:

view plain
  1. > t.find()  
  2. { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC",  
  3. "comments" : [ { "by" : "joe", "votes" : 3 }, { "by" : "jane", "votes" : 7 } ] }  
  4. > t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false, true )  
  5. > t.find()  
  6. { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC",  
  7. "comments" : [ { "by" : "joe", "votes" : 4 }, { "by" : "jane", "votes" : 7 } ] }  

但是"$"操作符僅支援一維數組的定位,在更新多維陣列時會返回錯誤資訊,例如有如下資料結構:

view plain
  1. {  
  2. "_id":ObjectId("4b97e62bf1d8c7152c9ccb74"),  
  3. ”comments“:[  
  4.   {  
  5.   "by":"joe",  
  6.   "votes":3,  
  7.   "replies":[  
  8.               {"by":"jane",  
  9.               "votes":2  
  10.              }]  
  11.    }]  
  12. }  

如果要將"replies"中{“by”:"jane"}的投票數增加1,該如何做呢(使用"$"mongodb會返回錯誤)?

mongodb使用多維陣列下標的方式來定位某個元素,那麼我們的方法就有了:

先find({"comments.replies.by":"jane"})來擷取到整個object,然後計算相應reply的數組下標,再使 用update({"comments.0.replies.0.by":"jane"},{"$inc", {"comments.0.replies.0.votes":1}}),即可,這樣就沒有同步的問題了。

 

ps:其實比較好的方法是由使用者用戶端程式來提供這個下標,即mongodb用戶端不要到伺服器擷取這個多維陣列再計算下標,效率太慢了。如果這個多維陣列已經呈現給使用者的話,那麼完全可以由使用者端的程式來提供這個下標,這樣效率是很高的。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.