zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    MySQL 子查询
    mysql3
    mysql2
    mysql
    C语言理论知识
    冒泡排序
    猜数字游戏
    WPF清爽酷炫的界面Mahapps.metro
    如何在.net4.0中使用.net4.5的async/await
    在C#中使用官方驱动操作MongoDB
  • 原文地址:https://www.cnblogs.com/jghdream/p/3545423.html
Copyright © 2011-2022 走看看