MongoDB查找命令find,让数据返回称心如意

业务系统接入数据库后,每天都有大量的数据写入数据库。面对逐日增加的数据,开发人员或数据分析人员,该如何读取数据,怎样设置条件,从数据库中查询数据?

本文基于mongodb的官方文档,整理出find命令的基本用法。

构建测试集

向inventory集合中插入5条数据

db.inventory.insertMany([{ item: "journal", qty: 25, size: { h: 14, w: 21, uom: "cm" }, status: "A" },{ item: "notebook", qty: 50, size: { h: 8.5, w: 11, uom: "in" }, status: "A" },{ item: "paper", qty: 100, size: { h: 8.5, w: 11, uom: "in" }, status: "D" },{ item: "planner", qty: 75, size: { h: 22.85, w: 30, uom: "cm" }, status: "D" },{ item: "postcard", qty: 45, size: { h: 10, w: 15.25, uom: "cm" }, status: "A" }
])

查询所有数据

在find命令中,不指定过滤器或添加一个空的过滤器,即可查询集合中所有数据。

db.inventory.find()
db.inventory.find({})

使用find查询时,返回结果是一个游标。使用mongosh或使用其他连接工具查询数据时,客户端默认通过该游标获取前面几条数据。用户需要移动游标来读取更多数据。

本测试集中只有5条数据,客户端自动移动游标获取全部数据。

等值查询

在查询过滤器中添加键值对,实现等值查询

{<field1>: <value1>, ...}

如查询集合inventory中状态为D的数据

db.inventory.find({status: "D"})

使用操作符指定查询条件

$in操作符

使用$in操作符,查询符合数组中元素的字段

//查询status是A或D的字段
db.inventory.find({status: {$in: ['A', 'D']}})

使用逻辑操作符复合查询

复合查询,指多余一个过滤条件的查询。

$and操作符

通常情况下,可以隐式的使用$and操作符建立符合查询。查询出符合所有指定过滤条件的文档。

db.inventory.find({status: "A", qty: {$lt: 30}})

如上面的查询语句,查询出符合status是A,并且符合qty大于30的文档

当显示的写出$and操作符时,查询语句变成下面的语句

db.inventory.find({$and: [{status: "A"}, {qty: {$lt: 30}}]})

$or操作符

使用$or操作符,查询出至少满足一个过滤条件的文档。如下面的查询中,查询出满足status是A,或qty大于30的文档,或者查询出同时满足下面两个条件的文档。

db.inventory.find({$or: [{status: "A"}, {qty: {$lt:30}}]})

$and与$or共用

当$and与$or共用时,可以建立更复杂的查询。下面的语句,查询出status为A的文档,同时满足qty小于30或item以“p”字符开头的数据。

db.inventory.find({status: 'A', $or: [{qty: {$lt: 30}},{item: /^p/}]})

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

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

相关文章

SpringBoot+Hutool实现图片验证码

图片验证码在注册、登录、交易、交互等各类场景中都发挥着巨大作用&#xff0c;能够防止操作者利用机器进行暴力破解、恶意注册、滥用服务、批量化操作和自动发布等行为。 创建一个实体类封装&#xff0c;给前端返回的验证码数据&#xff1a; Data public class ValidateCodeV…

中国智造闪耀CES | 木牛科技在美国CES展亮相多领域毫米波雷达尖端方案

素有全球科技潮流“风向标”之称的2024国际消费类电子产品展&#xff08;CES&#xff09;&#xff0c;于1月9-12日在美国拉斯维加斯会议中心举办。CES是全球最大的消费电子和消费技术展览会之一&#xff0c;汇集了世界各地优秀的消费电子和科技公司&#xff0c;带着最好的产品来…

关于BLE通信中WithoutResponse详细介绍

什么是WithoutResponse 在蓝牙低功耗&#xff08;BLE&#xff09;协议栈中&#xff0c;Characteristic 的写操作具有两种属性&#xff0c;分别为 "write" 和 "writeWithoutResponse"。 使用 "write" 属性发送命令时&#xff0c;需要接收端发送…

阿赵UE学习笔记——9、材质和材质实例

阿赵UE学习笔记目录 大家好&#xff0c;我是阿赵。   继续学习虚幻引擎&#xff0c;这次来了解一下UE里面关于材质的一些概念性的东西。 一、材质 材质这个概念&#xff0c;在所有三维软件里面都会有&#xff0c;比如3Dsmax里面的材质球&#xff0c;或者Unity里面的Material…

企业是否需要呼叫外包

随着企业的不断扩大业务不断增加&#xff0c;对于外呼和企业客服的质量有着更高的要求了&#xff0c;本着专业的人干专业的事情&#xff0c;呼叫中心外包服务成为许多企业的不二选择。然而&#xff0c;对于企业是否应该合作外包呼叫中心&#xff0c;仍需要从多个角度进行考虑。…

Python3 安装教程(windows)

Python &#xff08;官网&#xff09;是这两年来比较流行的一门编程语言。相对简单的语法以及丰富的第三方库。 步骤有三步&#xff1a; 1.下载 Python 安装包 2.安装 Python 3.查验是否安装成功 一.下载 Python 安装包 &#xff08;Python、Sublime 官方下载地址是外国的服…

Android Canvas图层saveLayer剪切clipPath原图addCircle绘制对应圆形区域并放大,Kotlin(3)

Android Canvas图层saveLayer剪切clipPath原图addCircle绘制对应圆形区域并放大&#xff0c;Kotlin&#xff08;3&#xff09; 在文章2 Android Canvas图层saveLayer剪切clipPath原图addCircle绘制对应圆形区域&#xff0c;Kotlin&#xff08;2&#xff09;-CSDN博客 的基础上&…

NVIDIA GPU 与服务器型号匹配查询

NVIDIA GPU 与服务器型号匹配查询 1. Qualified System Catalog (认证服务器目录)2. NVIDIA L40S2.1. NVIDIA L40S GPU Specifications References 1. Qualified System Catalog (认证服务器目录) https://www.nvidia.cn/data-center/data-center-gpus/qualified-system-catal…

jmeter监控服务器资源使用情况

GitHub - undera/perfmon-agent: Server metrics fetching agent, based on SIGAR 下载安装包&#xff1a;ServerAgent-2.2.3.zip 解压先 启动&#xff0c;如果是windows运行startAgent.bat&#xff0c;如果是linux运行startAgent.sh 注意&#xff1a;linux上注意权限的问题…

NPN PNP磁性开关区别

自记&#xff1a; 网上有些前后内容是相反的&#xff0c;估计自己就没明白&#xff0c;此为分析后得出结论&#xff0c;看完后可懂 1、NPN&#xff08;源型&#xff09;&#xff1a;当导通时输出低电平 当导通时&#xff0c;信号输出线out和0v线连接&#xff0c;相当于输出低电…

还不会python 实现常用的数据编码和对称加密?看这篇文章就够啦~

相信很多使用 python 的小伙伴在工作中都遇到过&#xff0c;对数据进行相关编码或加密的需求&#xff0c;今天这篇文章主要给大家介绍对于一些常用的数据编码和数据加密的方式&#xff0c;如何使用 python 去实现。话不多说&#xff0c;接下来直接进入主题&#xff1a; 前言 1…

基于6个IGBT的全桥电路simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 三相逆变器全桥电路原理 4.2 全桥电路应用领域 5.完整工程文件 1.课题概述 基于6个IGBT的全桥电路simulink建模与仿真. 2.系统仿真结果 3.核心程序与模型 版本&#xff1a;MATLAB2022a 02_018m …