MongoDB - 集合方法 db.collection.find()

文章目录

      • 1. query 参数
      • 2. projection 参数
        • 2.1 仅返回指定的字段
        • 2.2 排除字段
        • 2.3 显式排除_id字段
      • 3. 修改游标行为
        • 3.1 为结果集中的文档排序
        • 3.2 限制要返回的文档数量
        • 3.3 控制结果集的起点
        • 3.4 组合游标方法

db.collection.find( <query>, <projection>, <options> )
ParameterTypeDescription
querydocument可选。使用查询运算符指定选择筛选器。
projectiondocument可选。指定与查询过滤器匹配的文档中要返回的字段。
optionsdocument可选。指定查询的附加选项。

projection 参数确定匹配文档中返回哪些字段。projection 参数采用以下形式的文档:

{ <field1>: <value>, <field2>: <value> ... }

构造测试数据:

db.inventory.insertMany( [{ _id: 1, item: { name: "ab", code: "123" }, qty: 15, tags: [ "A", "B", "C" ] },{ _id: 2, item: { name: "cd", code: "123" }, qty: 20, tags: [ "B" ] },{ _id: 3, item: { name: "ij", code: "456" }, qty: 25, tags: [ "A", "B" ] },{ _id: 4, item: { name: "xy", code: "456" }, qty: 30, tags: [ "B", "A" ] },{ _id: 5, item: { name: "mn", code: "000" }, qty: 20, tags: [ [ "A", "B" ], "C" ] }
] )

1. query 参数

db.inventory.find({})
db.inventory.find( { _id: 5 } )
db.inventory.find( { "item.name": "ab" } )
db.inventory.find({ _id: { $in: [ 1, 2 ] } }
)

2. projection 参数

2.1 仅返回指定的字段
db.inventory.find( { qty: 20 },{ "item.name": 1, tags: 1 }
)
// 1
{"_id": 2,"item": {"name": "cd"},"tags": ["B"]
}// 2
{"_id": 5,"item": {"name": "mn"},"tags": [["A","B"],"C"]
}
2.2 排除字段

除非在投影文档 _id: 0 中显式排除 _id 字段,否则将返回 _id 字段。

db.inventory.find({ qty: 20 },{ "item.name": 0, tags: 0 }
)
// 1
{"_id": 2,"item": {"code": "123"},"qty": 20
}// 2
{"_id": 5,"item": {"code": "000"},"qty": 20
}
2.3 显式排除_id字段
db.inventory.find( { qty: 20 },{ "item.name": 1, tags: 1 ,_id: 0}
)
// 1
{"item": {"name": "cd"},"tags": ["B"]
}// 2
{"item": {"name": "mn"},"tags": [["A","B"],"C"]
}

3. 修改游标行为

3.1 为结果集中的文档排序

sort() 方法对结果集中的文档排序。

db.inventory.find({},{ _id: 0, tags: 0, item: 0}
).sort( { qty: 1 } )
// 1
{"qty": 15
}// 2
{"qty": 20
}// 3
{"qty": 20
}// 4
{"qty": 25
}// 5
{"qty": 30
}
3.2 限制要返回的文档数量

limit() 方法限制结果集中的文档数量。

db.inventory.find().limit(2)
// 1
{"_id": 1,"item": {"name": "ab","code": "123"},"qty": 15,"tags": ["A","B","C"]
}// 2
{"_id": 2,"item": {"name": "cd","code": "123"},"qty": 20,"tags": ["B"]
}
3.3 控制结果集的起点

skip() 方法控制结果集的起点。

db.inventory.find().skip( 3 )
// 1
{"_id": 4,"item": {"name": "xy","code": "456"},"qty": 30,"tags": ["B","A"]
}// 2
{"_id": 5,"item": {"name": "mn","code": "000"},"qty": 20,"tags": [["A", "B"],"C"]
}
3.4 组合游标方法
db.inventory.find().sort( { qty: 1 } ).limit( 2 )
db.bios.find().limit( 2 ).sort( { qty: 1 } )

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/50126.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【日常记录】【插件】Typed.js:用于创建打字效果的 JavaScript 库

文章目录 1. 引言2. 安装3. 基本使用参考链接 1. 引言 Typed.js是一个用于创建打字效果的 JavaScript 库。这个效果就是 chatgpt、百度的文心一言等其他的大模型&#xff0c;回复用户的问题的时候的效果 typed-js 官网typed 案例 2. 安装 CDN方式 这俩都可以&#xff0c;还有其…

18.springboot整合swagger

springboot整合swagger 引入依赖 <!--swagger--> <dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.9.2</version> </dependency> <dependency><groupId&…

Postman设置全部请求都携带请求头,Postman如何一次性设置请求头、不需要一个请求一个请求去添加请求头

文章目录 一、问题描述二、解决办法三、应用场景 一、问题描述 现在我有 n 个接口测试&#xff0c;其中 n 个都需要携带一致的请求头&#xff08;其实一般都是携带 JWT 令牌&#xff09;&#xff0c;怎么办&#xff1f;我要一个一个写&#xff1f;如图&#xff1a; 二、解决办…

C#从Socket里获取IP地址和端口号

在C#中&#xff0c;可以使用Socket类的RemoteEndPoint属性来获取连接的远程IP地址和端口号。以下是一个简单的示例代码&#xff0c;展示了如何从一个已连接的Socket实例中提取IP地址和端口号&#xff1a; using System; using System.Net; using System.Net.Sockets;public cl…

添加sidecar容器并输出日志

添加一个sidecar容器(使用busybox 镜像)到已有的pod 11-factor-app中,确保sidecar容器能够输出/var/log/11-factor-app.log的信息,使用volume挂载/var/log目录,确保sidecar能访问11-factor-app.log 文件 # 准备工作 创建一个 pod 11-factor-appapiVersion: v1 kind: Pod metada…

PDF管理器和查看器PdfDing

什么是 PdfDing &#xff1f; PdfDing 是一款自托管 PDF 管理器和查看器&#xff0c;可在多种设备上提供无缝用户体验。它设计精简、速度快&#xff0c;并且易于通过 Docker 设置。 功能特点 在多种设备上无缝基于浏览器的 PDF 查看使用标签整理 PDF干净且响应迅速的用户界面暗…

VulnHub:colddbox easy

靶机下载地址 信息收集 主机发现 攻击机网段192.168.31.0/24&#xff0c;扫描同网段存活主机。 nmap 192.168.31.0/24 -Pn -T4 发现靶机&#xff0c;IP为192.168.31.176。 端口扫描 扫描靶机开放端口。 nmap 192.168.31.176 -A -p- -T4 开放了80,4512端口&#xff0c;注…

Prometheus安装部署

文章目录 1.Prometheus(普罗米修斯)安装部署1.1部署环境准备1.2部署prometheus1.3主机数据展示 2.Grafana安装部署2.1部署Grafana2.2配置Grafana数据源2.2配置Grafana仪表板 3.AlertManager安装部署3.1部署alertmanager3.2告警邮件发送配置3.3测试邮件告警效果3.4自定义邮件告警…

ModuleNotFoundError: No module named ‘py3langid‘ 以及如何将包安在虚拟环境下

前提&#xff1a;已经安装过改包&#xff08;pip install py3langid&#xff09;&#xff0c;但仍报错 原因&#xff1a;安装在其他目录下了 解决办法&#xff1a; 1、再次在终端输入pip install py3langid 显示安装位置 Requirement already satisfied: py3langid in c:\…

【ESP8684————固件烧录说明、调试记录(1)】

环境&#xff1a; 硬件&#xff1a;ESP8684 模块 芯片&#xff1a;ESP8684-MINI-1U 固件&#xff1a;ESP32-C2-4MB-AT-V3.3.0.0 固件烧录及烧录说明整理&#xff1a;固件及烧录说明整理 一、调试笔记&#xff1a; 1&#xff09;关于ESP8684模块&#xff08;ATCWMODE&#xf…

【Python】快速创建一个简易 HTTP 服务器(http.server)

目录 官方文档安装教程用命令行创建编写代码创建 实例 官方文档 http.server 警告&#xff1a; http.server 不推荐用于生产环境。它仅仅实现了 basic security checks 的要求。 安装 Python3 内置标准模块&#xff0c;无需安装。&#xff08;在之前的 Python2 版本名称是 Si…

Jmeter三种方式获取数组中多个数据并将其当做下个接口参数入参【附带JSON提取器和CSV格式化】

目录 一、传统方式-JOSN提取器获取接口返回值 1、接口调用获取返回值 2、添加JSON提取器 3、调试程序查看结果 4、添加循环控制器 5、设置count计数器 6、添加请求 7、执行请求 二、CSV参数化 1、将结果写入后置处理程序 2、设置循环处理器 3、添加CSV文件 4、设置…

C++通过JNI传递AssetManager读取安卓assets目录中文件

在 Android 设备上&#xff0c;assets 目录位于应用程序的 APK 包内部&#xff0c;它并不直接暴露在设备的文件系统中。因此&#xff0c;无法通过传统的文件路径直接访问 assets 目录下的文件。访问 assets 目录下的文件通常通过 AssetManager 来实现。 就可以实现将C需要的文…

计算机网络中的 CDN 与内容分发网络

引言 在现代互联网中&#xff0c;用户期望能够快速、稳定地访问各种在线内容。内容分发网络&#xff08;Content Delivery Network&#xff0c;简称 CDN&#xff09;应运而生&#xff0c;成为解决这一需求的关键技术。CDN 是一种分布式的服务器系统&#xff0c;通过将内容缓存…

智税集成2.0生成凭证

:::info &#x1f4a1; 整体业务流程 从A9服务器中取数&#xff0c;生成列表数据&#xff0c;写入到对方oracle数据库中。 ::: 项目关键点 1.连接数据库 左连接连接本地SQLserver数据库、右连接要链接A9开票服务器的数据库然后设想用SQLserver 自带的外部连接来连接oracle数据…

机器学习·线性回归

线性回归 损失函数 J ( w , b ) 1 2 m ∑ i 1 m ( f ( i ) ( w 1 , w 2 , … , w j , b ) − y ( i ) ) 2 J(w,b)\frac{1}{2m}\sum_{i1}^{m}\left({f^{(i)}(w_1,w_2,\ldots,w_j,b)-y^{(i)}} \right)^2 J(w,b)2m1​i1∑m​(f(i)(w1​,w2​,…,wj​,b)−y(i))2 梯度下降方法 …

【资料分享】2024第三届钉钉杯大学生大数据挑战赛B题思路解析+双语言代码

2024钉钉杯大学生大数据挑战赛&#xff0c;B题解题思路和双语言代码分享&#xff0c;资料预览&#xff1a;

机房建设及运维方案

随着信息技术的快速发展&#xff0c;机房作为企业数据处理与存储的核心场所&#xff0c;其重要性日益凸显。机房的建设不仅关乎到企业业务的正常运行&#xff0c;更与企业的长期发展紧密相连。为了确保机房设备的稳定运行和业务的连续性&#xff0c;本文将从机房建设及运维两个…

解密阿里大神写的天书般的Tree工具类,轻松搞定树结构!

首发公众号&#xff1a;赵侠客 一、引言 最近公司新进了不少新人&#xff0c;包括一些来自阿里、网易等大型企业的资深工程师。我们组的一位新同事是阿里来的专家&#xff0c;我在CR&#xff08;Code Review, 简称CR&#xff09;时看到了他编写的一个关于树操作的工具类&#…

操作系统:进程1

一.进程 1.什么是进程 一个进程创建&#xff0c;他会生成几块&#xff1a; 代码段&#xff1a;进程执行的程序代码数据段&#xff1a;全局变量&#xff0c;静态变量&#xff0c;在进程生命周期中是动态可变的堆&#xff1a;动态分配的内存区域&#xff0c;malloc、calloc、real…