首页 > 数据库技术 > 详细

MongoDB 语法陷阱(转自51CTO)

时间:2014-02-12 16:55:57      阅读:499      评论:0      收藏:0      [点我收藏+]

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

MongoDB 语法陷阱(转自51CTO)

原文:http://www.cnblogs.com/jghdream/p/3545423.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!