mongodb高级查询

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mongodb高级查询相关的知识,希望对你有一定的参考价值。

  MongoDB 的逻辑结构是一种层次结构。主要由文档(document)、集合(collection)、数据库(database)这三部分组成的。逻辑结构是面向用户的用户使用MongoDB 开发应用程序使用的就是逻辑结构。

  MongoDB 的文档document相当于关系数据库中的一行记录。

  多个文档组成一个集合collection相当于关系数据库的表。

  多个集合collection逻辑上组织在一起就是数据库database。

  一个MongoDB 实例支持多个数据库database。

mongodb条件查询

   db.collection.find({"field":{$gt:value}}) //大于

   db.collection.find({ "field" : { $lt: value } } ); // 小于: field < value

   db.collection.find({ "field" : { $gte: value } } ); // 大于等于: field >= value

   db.collection.find({ "field" : { $lte: value } } ); // 小于等于: field <= value

   如果要同时满足多个条件可以这样做

    db.collection.find({ "field" : { $gt: value1, $lt: value2 } } ); // value1 < field < value

   

    $all匹配所有 必须满足[ ]内的所有值例如:

    db.users.find({age : {$all : [6, 8]}});

    可以查询出 {name: ‘David‘, age: 26, age: [ 6, 8, 9 ] }

    但查询不出 {name: ‘David‘, age: 26, age: [ 6, 7, 9 ] }


    $exists判断字段是否存在

    查询所有存在age 字段的记录

    db.users.find({age: {$exists: true}});

    查询所有不存在name 字段的记录

    db.users.find({name: {$exists: false}});

    

    $ne不等于

    查询x 的值不等于3 的数据

    db.things.find( { x : { $ne : 3 } } );


    $in包含

    查询x 的值在2,4,6 范围内的数据

    db.things.find({x:{$in: [2,4,6]}});

  

    $nin不包含

   查询x 的值在2,4,6 范围外的数据

    db.things.find({x:{$nin: [2,4,6]}});

 

    $size数组元素个数

    对于{name: ‘David‘, age: 26, favorite_number: [ 6, 7, 9 ] }记录

    匹配db.users.find({favorite_number: {$size: 3}});

    不匹配db.users.find({favorite_number: {$size: 2}});

 

    正则表达式匹配

    查询不匹配name=B*带头的记录

    db.users.find({name: {$not: /^B.*/}});


    skip限制返回记录的起点

    从第3 条记录开始返回5 条记录(limit 3, 5)

    db.users.find().skip(3).limit(5);


    sort排序

    以年龄升序asc

    db.users.find().sort({age: 1});

    以年龄降序desc

    db.users.find().sort({age: -1});


以上是关于mongodb高级查询的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB高级查询用法

mongodb高级查询

使用 rmongodb 在 R 中运行高级 MongoDB 查询

mongodb高级查询

一个复杂的 MongoDB 查询(高级嵌套)

如何在 MongoDB 中执行高级子文档查询?