广告
返回顶部
首页 > 资讯 > 数据库 >Mongo高级查询
  • 236
分享到

Mongo高级查询

2024-04-02 19:04:59 236人浏览 薄情痞子
摘要

1、条件操作符(1)条件操作符db.collection.find({ "field" : { $gt: value } } ); // 大于: field > valuedb.collection.

1、条件操作符


(1)条件操作符

db.collection.find({ "field" : { $gt: value } } ); // 大于: field > 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


(2)$all匹配所有

这个操作符跟sql 语法的in 类似,但不同的是, in 只需满足( )内的某一个值即可, 而$all 必

须满足[ ]内的所有值,例如:

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

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

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


(3)$exists判断字段在不在

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

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

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

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


(4)Null值处理

Null不仅能找到自身而且还能找到不存在某个字段的值


(5)$mod取模运算

取模6为1的

> db.user.find()

{ "_id" : ObjectId("4fb4af85afa87dc1bed94330"), "age" : 7, "length_1" : 30 }

{ "_id" : ObjectId("4fb4af89afa87dc1bed94331"), "age" : 8, "length_1" : 30 }

{ "_id" : ObjectId("4fb4af8cafa87dc1bed94332"), "age" : 6, "length_1" : 30 }

> db.user.find({age:{$mod:[6,1]}})

{ "_id" : ObjectId("4fb4af85afa87dc1bed94330"), "age" : 7, "length_1" : 30 }

(5)$ne不等于

查询age 的值不等于7 的数据

> db.user.find({age:{$ne:6}})

{ "_id" : ObjectId("4fb4af85afa87dc1bed94330"), "age" : 7, "length_1" : 30 }

{ "_id" : ObjectId("4fb4af89afa87dc1bed94331"), "age" : 8, "length_1" : 30 }

> db.user.find({age:{$ne:7}})

{ "_id" : ObjectId("4fb4af89afa87dc1bed94331"), "age" : 8, "length_1" : 30 }

{ "_id" : ObjectId("4fb4af8cafa87dc1bed94332"), "age" : 6, "length_1" : 30 }


(6)$in包含

查询age 的值在7,8 范围内的数据

> db.user.find({age:{$in:[7,8]}})

{ "_id" : ObjectId("4fb4af85afa87dc1bed94330"), "age" : 7, "length_1" : 30 }

{ "_id" : ObjectId("4fb4af89afa87dc1bed94331"), "age" : 8, "length_1" : 30 }


(7)min不包含

查询age 的值在7,8 范围外的数据

> db.user.find({age:{$nin:[7,8]}})

{ "_id" : ObjectId("4fb4af8cafa87dc1bed94332"), "age" : 6, "length_1" : 30 }


(8)$size数组元素个数

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

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

> db.user.find({favorite_number:{$size:3}})

{ "_id" : ObjectId("579eee3D8aeb5abda0d54b5e"), "name" : "David", "age" : 26, "favorite_number" : [ 6, 7, 9 ] }

> db.user.find({favorite_number:{$size:2}})

>


(9)正则表达式匹配

查询name 不以T 开头的数据

db.user.find()

{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

> db.user.find({name:{$not:/^T.*/}})

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

>


(10) javascript查询和$where查询

查询a 大于3 的数据,下面的查询方法殊途同归

 db.c1.find( { a : { $gt: 3 } } );

 db.c1.find( { $where: "this.a > 3" } );

 db.c1.find("this.a > 3");

 f = function() { return this.a > 3; } db.c1.find(f);


(11)count查询记录条数

> db.user.find()

{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

> db.user.find().count()

2

>


(12)skip限制返回记录的起点

查询user中的第2条数据

> db.user.find()

{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

> db.user.find().skip(1).limit(1)

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

>


(13)sort排序

查询c1 表按age 升序排列

> db.user.find().sort({age:-1})

{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

> db.user.find().sort({age:1})

{ "_id" : ObjectId("4fb5fab96d0f9d8ea3fc91a9"), "name" : "Joe", "age" : 10 }

{ "_id" : ObjectId("4fb5faaf6d0f9d8ea3fc91a8"), "name" : "Tony", "age" : 20 }

>


(14)游标

for (var i=1;i<10;i++) db.user.insert( {"x" : i})


> for(var c=db.user.find();c.hasNext();){printJSON(c.next());}

{ "_id" : ObjectId("579ef6198aeb5abda0d54b5f"), "x" : 1 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b60"), "x" : 2 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b61"), "x" : 3 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b62"), "x" : 4 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b63"), "x" : 5 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b64"), "x" : 6 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b65"), "x" : 7 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b66"), "x" : 8 }

{ "_id" : ObjectId("579ef6198aeb5abda0d54b67"), "x" : 9 }

>


 


您可能感兴趣的文档:

--结束END--

本文标题: Mongo高级查询

本文链接: https://www.lsjlt.com/news/40018.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mongo高级查询
    1、条件操作符(1)条件操作符db.collection.find({ "field" : { $gt: value } } ); // 大于: field > valuedb.collection....
    99+
    2022-10-18
  • golang查询mongo
    Golang是一种快速、简洁、安全而具有高效的编程语言,受到了广泛的关注和应用。MongoDB则是一种无模式、文档型数据库,是现代应用程序的首选数据库之一。Golang和MongoDB的结合,能够为开发人员带来很多好处。在本篇文章中,我们将...
    99+
    2023-05-21
  • mongo 聚合查询
    *****************未加索引******************************************> var startTime = new Date();> db....
    99+
    2022-10-18
  • mongodb高级查询
      MongoDB 的逻辑结构是一种层次结构。主要由文档(document)、集合(collection)、数据库(database)这三部分组成的。逻辑结构是面向用户的用户使用MongoDB 开...
    99+
    2022-10-18
  • Oracle高级查询
    本章将学习的内容有:如何使用集合操作符,集合操作符用于将两个或多个查询返回的行组合起来使用TRANSLATE函数1、使用集合操作符    操作符说明UNION...
    99+
    2022-10-18
  • T-SQL 高级查询
    T-SQL高级查询函数:是一个可反复使用的程序段从其他的程序段中使用调用语句来执行这段程序提前写好一段语句,取一个名字,使用时调用这个名字系统函数:转换数据类型,以及查看系统参数Convert():数据类型...
    99+
    2022-10-18
  • mongo中模糊查询怎么用
    这篇文章主要介绍了mongo中模糊查询怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。以下是一个mongo查询的综合应用,即介绍一个生产...
    99+
    2022-10-18
  • mongodb高级聚合查询
      https://www.cnblogs.com/zhoujie/p/mongo1.html mongodb高级聚合查询     在工作中会经常遇到一些mongodb的聚合操作,特此总结下。mongo存储的可以是复杂类型,比...
    99+
    2016-06-26
    mongodb高级聚合查询
  • mongo慢查询问题如何排查处理
    这篇文章主要介绍了mongo慢查询问题如何排查处理的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mongo慢查询问题如何排查处理文章都会有所收获,下面我们一起来看看吧。一、简单介绍mongo语句查询条件中出现n...
    99+
    2023-06-29
  • Mybatis-Plus高级查询LambdaQueryWrapper&QueryWrapper
    目录 前言 Wrapper 查询构造器 查询条件 前期准备 查询条件 allEq eq ne gt ge lt le between,notBetween like,notLike likeLeft likeRight isNull 空值...
    99+
    2023-08-31
    mysql 数据库 mybatis
  • 浅谈 T-SQL高级查询
    之前我们简单的了解了增、删、改、查这几类T-SQL语法来操纵数据表,但是为了更方便快捷地完成大量任务,SQL Server 提供了一些内部函数,可以和SQL Server 的SELECT语句来联合使...
    99+
    2022-10-18
  • Oracle 笔记之高级查询
    为列起别名目的 我们进行查询时 经常查询某一列时使用的是表达式 SELECT enamme,sal*12 FROM emp这样不好的地方是第二列在查询后列用使用的就是sal*12.这样的可读性比较差...
    99+
    2022-10-18
  • 【MySQL】细谈SQL高级查询
    文章目录 一、前言 & 准备工作二、简易高级查询⚙ 准备工作1、查询每一门课程及其先修课程2、查询和“刘涛”在一个班级的学生的信息3、查询选修了‘计算机基础’课的学生的学号、姓名③ 连接方式④ 子查询嵌套方式 4、查询没有...
    99+
    2023-12-23
    mysql sql 数据库
  • 整理最近用的Mongo查询语句
    整理最近正在用的多条件查询以及聚合查询的实例,作为文档保留供以后查阅 背景 最近做了几个规则逻辑。用到mongo查询比较多,就是查询交易信息跑既定规则筛选出交易商户,使用聚合管道进行统计和取出简单处理后的数据,用SQL代替业务...
    99+
    2021-09-25
    整理最近用的Mongo查询语句
  • spring boot整合mongo查询converter异常排查记录
    目录前言自定义转换器javabean的方式配置MongoTemplate后记:前言 使用过spring boot的人都知道spring boot约定优于配置的理念给我们开发中集成相关...
    99+
    2022-11-13
  • ynamicLINQ创建高级查询服务
    目录前言:一、创建高级查询服务二、使用DynamicLINQ创建高级查询服务​1.定义查询参数​​2.实现查询方法​​3.实现扩展方法​​4.效果​前言: 在业务开发中,一个常用的功...
    99+
    2022-11-13
  • MySQL高级(五)——慢查询日志
    具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中。long_query_time的默认值为10,意思是运行10秒以上的语句。 由他来查看哪些SQL超出了我们的最大忍耐时间值,比如一条sql执行超过...
    99+
    2018-03-26
    MySQL高级(五)——慢查询日志
  • Oracle高级查询之OVER (PARTITION BY ..)
    为了方便大家学习和测试,所有的例子都是在Oracle自带用户Scott下建立的。注:标题中的红色order by是说明在使用该方法的时候必须要带上order by。一、rank()/de...
    99+
    2022-10-18
  • MySQL高级查询语法分析
    目录一、排序二、分页查询三、聚合函数四、分组查询五、连接查询1. 内连接查询2. 左连接查询3. 右连接查询4. 自连接查询六、子查询一、排序 排序查询语法: select...
    99+
    2022-11-13
  • mongo:查询集合中所有字段名称
    解决方法有好多: 更多解决方法请参考:http://cn.voidcc.com/question... 我只提供一种简单的,速度相对快的: python的高级函数,没错思想就是集合去重。 from functools impo...
    99+
    2023-01-31
    字段 名称 mongo
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作