MongoDB 语法陷阱(转自51CTO)

1. 哈希对象中key的顺序

比如,你要存储一个简单的文字对象::

  1. > db.books.insert({ title: "Woe from Wit", meta: { author: "A. Griboyedov"year: 1823 } }); 

太棒了!现在我们有了一条书籍记录。再比如,以后我们会想找所有1823年出版的作者是 A. Griboyedov 的书。这里不太可能返回多个结果,但至少应该有《 Woe from Wit 》这本书,因为我们刚刚插入了这条记录,对不对?

  1. > db.books.find({ meta: { year: 1823, author: "A. Griboyedov" } }); 
  2. No results returned 

发生了什么?我们不是刚刚插入了这本书的数据吗?让我们尝试调换key的顺序:

  1. > db.books.find({ meta: { author: "A. Griboyedov"year: 1823 } }); 
  2. < { _id: ..., title: "Woe from Wit", meta: { ... } } 

搞定了!

陷阱: 在MongoDB中key的顺序非常重要,{ a: 1, b: 2 } 和 { b: 2, a: 1 }是不匹配的。

为什么: MongoDB使用叫做BSON的二进制数据格式。在BSON中key的顺序非常重要。注意,JSON对象是一个无序的键/值对集合。

 

原文:http://developer.51cto.com/art/201402/428716.htm

posted @ 2014-02-12 09:59  一粟沧海  阅读(153)  评论(0编辑  收藏  举报