首页 > 数据库技术 > 详细

mongodb用子文档做为查询条件的两种方法

时间:2016-05-25 10:48:01      阅读:294      评论:0      收藏:0      [点我收藏+]
    {
      "_id": ObjectId("52fc6617e97feebe05000000"),
      "age": 28,
      "level": NumberInt(500),
      "name": "name5",
      "person": [
        {
          "level": 5,
          "score": 100,
        "ccc":{"ccc3":56,"fff3":78}
        },
        {
          "level": 7,
          "score": 90,
          "like": "music"
        }
      ],
      "score": NumberInt(500),
      "sex": "男"
    }

  方法一:

db.testColl.find({"person.level":7});

db.testColl.find({"person.ccc.ccc3":56});

  

均可查出结果,就是说这种方法可以嵌套使用!

方法二、使用$elemMatch操作符

db.testColl.find({"person":{"$elemMatch":{"level":5}}});

  

可以查出结果

db.testColl.find({"person":{"$elemMatch":{"ccc":{"$elemMatch":{"ccc3":56}}}}});

  

无法查出结果

db.testColl.find({"person":{"$elemMatch":{"ccc":{"ccc3":56,"fff3":78}}}});

db.testColl.find({"person":{"$elemMatch":{"ccc.ccc3":56}}});

  

可以查出结果
也就是说第二种方法不能嵌套使用。 

mongodb用子文档做为查询条件的两种方法

原文:http://www.cnblogs.com/wuxiang/p/5525835.html

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