当前位置: 首页 > news >正文

mongo常用操作符及查询例子

比较操作符:
$eq:匹配字段值等于指定值。
$ne:匹配字段值不等于指定值。
$gt:匹配字段值大于指定值。
$gte:匹配字段值大于或等于指定值。
$lt:匹配字段值小于指定值。
$lte:匹配字段值小于或等于指定值.

逻辑操作符:
$and:匹配多个条件都满足的文档。
$or:匹配多个条件中至少一个满足的文档。
$not:匹配不满足条件的文档。
$nor:匹配多个条件都不满足的文档。

元素操作符:
$exists:匹配包含指定字段的文档。
$type:匹配指定数据类型的字段。

数组操作符:
$in:匹配数组字段中包含指定值的文档。
$nin:匹配数组字段中不包含指定值的文档。
$all:匹配数组字段中包含所有指定值的文档。
$size:匹配数组字段长度等于指定值的文档。

正则表达式操作符
$regex:匹配字段值符合指定正则表达式的文档。

文本搜索操作符:
$text:执行全文本搜索。
$meta:获取文本搜索得分。

元素更新操作符:
$set:设置字段的值。
$unset:删除字段。
$inc:递增字段的值。
$push:向数组字段添加元素。
$addToSet:向数组字段添加不重复的元素。
$pull:从数组字段中删除元素。

查询修改操作符:
$find:指定查询条件。
$update:指定更新的字段和值。
$sort:指定排序方式。
$limit:限制结果集的大小。
$skip:跳过指定数量的文档。

以下是一些常见类别的 MongoDB 查询操作符及其示例:

  1. 比较操作符:

    • $eq:匹配字段值等于指定值。

      db.collection.find({ age: { $eq: 25 } })
      
    • $ne:匹配字段值不等于指定值。

      db.collection.find({ status: { $ne: "inactive" } })
      
    • $gt:匹配字段值大于指定值。

      db.collection.find({ score: { $gt: 90 } })
      
    • $gte:匹配字段值大于或等于指定值。

      db.collection.find({ score: { $gte: 85 } })
      
    • $lt:匹配字段值小于指定值.

      db.collection.find({ price: { $lt: 100 } })
      
    • $lte:匹配字段值小于或等于指定值.

      db.collection.find({ age: { $lte: 30 } })
      
  2. 逻辑操作符:

    • $and:匹配多个条件都满足的文档。

      db.collection.find({ $and: [ { age: 25 }, { status: "active" } ] })
      
    • $or:匹配多个条件中至少一个满足的文档。

      db.collection.find({ $or: [ { role: "admin" }, { role: "manager" } ] })
      
    • $not:匹配不满足条件的文档。

      db.collection.find({ $not: { age: { $lt: 18 } } })
      
    • $nor:匹配多个条件都不满足的文档。

      db.collection.find({ $nor: [ { status: "inactive" }, { age: { $lt: 18 } } ] })
      
  3. 数组操作符:

    • $in:匹配数组字段中包含指定值的文档。

      db.collection.find({ tags: { $in: ["mongodb", "database"] } })
      
    • $nin:匹配数组字段中不包含指定值的文档。

      db.collection.find({ categories: { $nin: ["technology", "programming"] } })
      
    • $all:匹配数组字段中包含所有指定值的文档。

      db.collection.find({ ingredients: { $all: ["flour", "sugar"] } })
      
    • $size:匹配数组字段长度等于指定值的文档。

      db.collection.find({ tags: { $size: 3 } })
      

继续介绍一些 MongoDB 查询操作符的示例:

  1. 元素操作符:

    • $exists:匹配包含指定字段的文档。

      db.collection.find({ field_name: { $exists: true } })
      
    • $type:匹配指定数据类型的字段。

      db.collection.find({ field_name: { $type: "string" } })
      
  2. 正则表达式操作符:

    • $regex:匹配字段值符合指定正则表达式的文档。

      db.collection.find({ title: { $regex: /pattern/i } })
      
  3. 文本搜索操作符:

    • $text:执行全文本搜索。

      db.collection.find({ $text: { $search: "search term" } })
      
    • $meta:获取文本搜索得分。

      db.collection.find({ $text: { $search: "search term" } }, { score: { $meta: "textScore" } })
      
  4. 元素更新操作符:

    • $set:设置字段的值。

      db.collection.update({ _id: ObjectId("document_id") }, { $set: { field_name: new_value } })
      
    • $unset:删除字段。

      db.collection.update({ _id: ObjectId("document_id") }, { $unset: { field_name: 1 } })
      
    • $inc:递增字段的值。

      db.collection.update({ _id: ObjectId("document_id") }, { $inc: { quantity: 1 } })
      
    • $push:向数组字段添加元素。

      db.collection.update({ _id: ObjectId("document_id") }, { $push: { tags: "new_tag" } })
      
    • $addToSet:向数组字段添加不重复的元素。

      db.collection.update({ _id: ObjectId("document_id") }, { $addToSet: { unique_values: "new_value" } })
      
    • $pull:从数组字段中删除元素。

      db.collection.update({ _id: ObjectId("document_id") }, { $pull: { tags: "unwanted_tag" } })
      
  5. 查询修改操作符:

    • $find:指定查询条件。

      db.collection.find({ field_name: "value" })
      
    • $update:指定更新的字段和值。

      db.collection.update({ field_name: "value" }, { $set: { new_field: "new_value" } })
      
    • $sort:指定排序方式。

      db.collection.find().sort({ field_name: 1 }) // 升序
      
    • $limit:限制结果集的大小。

      db.collection.find().limit(10) // 限制为前10条文档
      
    • $skip:跳过指定数量的文档。

      db.collection.find().skip(10) // 跳过前10条文档

相关文章:

mongo常用操作符及查询例子

比较操作符: $eq:匹配字段值等于指定值。 $ne:匹配字段值不等于指定值。 $gt:匹配字段值大于指定值。 $gte:匹配字段值大于或等于指定值。 $lt:匹配字段值小于指定值。 $lte:匹配字段值小于或等…...

41.排序练习题(王道2023数据结构第8章综合练习)

试题1(王道8.3.3节综合练习2): 编写双向冒泡排序算法,在正反两个方向交替扫描。即第一趟把关键字最大的元素放在序列的最后面,第二趟把关键字最小的元素放在序列最前面,如此反复。 首先实现冒泡排序&…...

python爬虫,如何在代理的IP被封后立刻换下一个IP继续任务?

前言 在实际的爬虫应用中,爬虫程序经常会通过代理服务器来进行网络访问,以避免访问过于频繁而受到网站服务器的限制。但是,代理服务器的IP地址也可能被目标网站限制,导致无法正常访问。这时候,我们需要在代理IP被封后…...

小程序开发——小程序项目的配置与生命周期

1.app.json配置属性 app.json配置属性 2.页面配置 app的页面配置指的是pages属性, pages数组的第一个页面将默认作为小程序的启动页。利用开发工具新建页面时,则pages属性对应的数组将自动添加该页面的路径,若是在硬盘中添加文件的形式则不…...

C语言之用指针交换两个数

1.指针存放是是地址,所以在用指针交换两个数的时候,需要对指针进行解引用(*p)。 用指针交换两个数,需要知道p1p2与*p1*p2。 p1p1是将p2的值赋值给p1. *p1*p2是将p2指针地址存放的值,赋值给p1指针地址存放的值,即p1地…...

Day 48 动态规划 part14

Day 48 动态规划 part14 解题理解1143103553 3道题目 1143. 最长公共子序列 1035. 不相交的线 53. 最大子数组和 解题理解 1143 设dp[i][j]为text10: i-1text20: j-1的最长公共子序列。 class Solution:def longestCommonSubsequence(self, text1: str, text2: str) -> …...

目标检测与图像识别分类的区别?

目标检测与图像识别分类的区别 目标检测和图像识别分类是计算机视觉领域中两个重要的任务,它们在处理图像数据时有一些区别。 目标检测是指在图像中定位和识别多个目标的过程。其主要目标是确定图像中每个目标的边界框位置以及对应的类别标签。目标检测任务通常涉…...

群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新)

起因&解决思路 事情的开始大概是这样的。。godaddy买了个域名,好好的用了半个月。。然后一直更新失败发现被狗东西墙了 在提一嘴DDNS-GO 解析失败原因 DDNS-GO必须要先向godaddy请求自己的IP地址[这里被墙卡住了],然后比对,再决定是否上…...

博客摘录「 MySQL不区分大小写设置」2023年10月31日

操作系统的大小写是否敏感决定了数据库大小写是否敏感,而 Windows 系统是对大小写不敏感的,Linux 系统对大小写敏感。 mysql创建表时, 字符集需要设置"编码集(charset)"和"校验规则(collation)"。 编码集比较常用的有utf8和utf8mb4…...

【UE5】如何在UE5.1中创建级联粒子系统

1. 可以先新建一个actor蓝图,然后在该蓝图中添加一个“Cascade Particle System Component” 2. 在右侧的细节面板中,点击“模板”一项中的下拉框,然后点击“Cascade粒子系统(旧版)” 然后就可以选择在哪个路径下创建级…...

SpringCloud(五) Eureka与Nacos的区别

SpringCloud(二) Eureka注册中心的使用-CSDN博客 SpringCloud(四) Nacos注册中心-CSDN博客 在这两篇博文中我们详细讲解了Eureka和Nacos分别作为微服务的注册中心的使用方法和注意事项,但是两者之间也有一些区别. 一, Nacos实例分类 Nacos实例分为两种类型: 临时实例:如果实例…...

C语言 DAY07:预编译,宏,选择性编译,库(静态库,动态库)

声明与定义分离 声明:将声明单独封装成一个以.h为后缀名的头文件 定义:将定义的变量,函数,数组所在的源文件单独封装成一个.c文件。其实就是在源文件基础上将定义过的所有东西的声明分离出去就是了。 注意:1.声明的…...

[EFI]asus strix b760-i 13900F电脑 Hackintosh 黑苹果efi引导文件

硬件型号驱动情况主板 asus strix b760-i 处理器 I9 13900F 已驱动内存crucial ddr5-5200 64gb(32gb*2)(overclock 5600)已驱动硬盘 WD black sn850 500g*2 已驱动显卡rx570已驱动声卡Realtek ALCS1220A已驱动网卡Intel I225-V 2.5 Gigabit Ethernet已驱动无线网卡蓝牙Fevi T91…...

力扣383.赎金信

原题链接:383.赎金信 根据题意得出,需要判断第一个字符串内的字符有没有都在第二个字符串内出现(会有重复字符),并且范围限制在26个英文小写字母 此时可以考虑用一个数组map 作哈希法映射操作 先将遍历第一个字符串,并让每个字符…...

CORS的原理以及在Node.js中的使用

在前端浏览器中的JavaScript代码发起HTTP请求到服务器的Node.js程序,CORS(跨域资源共享)会在以下几个步骤中发挥作用: 前端JavaScript代码发起请求: 前端浏览器中的JavaScript代码使用XMLHttpRequest对象或Fetch API等…...

kotlin实现单例模式

kotlin实现单例模式,大体分为两种方式,一种饿汉式单例模式,一种懒汉式单例模式。 1.饿汉式单例模式 在类前面加上object关键字,就实现了饿汉式单例模式: object singletonDemo { }在kotlin中,使用这种方式…...

【Java】LinkedList 集合

LinkedList集合特点 LinkedList 底层基于双向链表实现增删 效率非常高,查询效率非常低。 LinkedList源码解读分析 LinkedList 是双向链表实现的 ListLinkedList 是非线程安全的(线程是不安全的)LinkedList 元素允许为null,允许重复元素Linked…...

MySQL-Galera-Cluster集群详细介绍

目录 一、什么是Mysql集群?1.单节点mysql存在的常见问题2.mysql集群介绍3.Mysql集群的优点和风险 二、Mysql集群的一些疑问1.mysql的AB复制和Galera Cluster有什么区别?2.什么情况下适用AB复制,什么情况下使用Galera cluster?3.可…...

JavaScript从入门到精通系列第二十六篇:详解JavaScript中的Math对象

大神链接:作者有幸结识技术大神孙哥为好友,获益匪浅。现在把孙哥视频分享给大家。 孙哥连接:孙哥个人主页 作者简介:一个颜值99分,只比孙哥差一点的程序员 本专栏简介:话不多说,让我们一起干翻J…...

u盘直接拔出文件丢失怎么找回?u盘文件恢复办法分享!

u盘作为一种便捷的数据存储设备,被广泛地使用。通过u盘,我们可以在不同设备之间轻松传输文件,然而有时候,我们可能因为匆忙或疏忽并未安全弹出u盘,而是直接将u盘拔出,进而导致重要文件丢失,u盘直…...

HunyuanVideo-Foley保姆级教程:从零部署到音效生成的5个关键步骤

HunyuanVideo-Foley保姆级教程:从零部署到音效生成的5个关键步骤 1. 环境准备与镜像部署 1.1 硬件要求检查 在开始部署前,请确保您的设备满足以下最低配置要求: 显卡:NVIDIA RTX 4090/4090D(24GB显存)内…...

AutoUnipus:重新定义U校园学习效率的智能解决方案

AutoUnipus:重新定义U校园学习效率的智能解决方案 【免费下载链接】AutoUnipus U校园脚本,支持全自动答题,百分百正确 2024最新版 项目地址: https://gitcode.com/gh_mirrors/au/AutoUnipus 还在为U校园平台上堆积如山的网课任务而焦虑吗?每天花费…...

FreeRTOS实战指南:从消息队列到内存管理,手把手解决嵌入式多任务难题

FreeRTOS实战指南:从消息队列到内存管理,手把手解决嵌入式多任务难题 1. 为什么嵌入式开发者需要FreeRTOS 在资源受限的嵌入式系统中,开发者常常面临这样的困境:既要处理实时性要求高的传感器数据采集,又要兼顾用户界面…...

如何快速使用OpCore Simplify:零基础黑苹果的终极配置指南

如何快速使用OpCore Simplify:零基础黑苹果的终极配置指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为复杂的OpenCore配置而烦恼…...

当地的美国展会搭建制作公司口碑排行

随着中国企业出海参展日益频繁,选择一家可靠的美国本土搭建商成为关键决策。许多企业主发现,直接对接海外供应商时,常面临沟通不畅、报价模糊、落地效果与设计图相差甚远等问题。这背后,是原有依赖单一信息渠道或熟人推荐的模式正…...

ENVI 5.3波谱库实战:从自带库浏览到自定义库创建,遥感地物识别效率翻倍

ENVI 5.3波谱库实战:从自带库浏览到自定义库创建,遥感地物识别效率翻倍 在遥感图像解译工作中,地物波谱特征就像每类物质的"光学指纹"。ENVI 5.3的波谱库功能,正是帮助我们从海量遥感数据中快速匹配这些"指纹"…...

SDMatte抠图实战教程:玻璃/薄纱/羽毛一键去背景,保姆级Web部署指南

SDMatte抠图实战教程:玻璃/薄纱/羽毛一键去背景,保姆级Web部署指南 1. 为什么选择SDMatte进行专业抠图 在日常设计工作中,抠图是最基础也最耗时的环节之一。特别是遇到玻璃制品、薄纱材质、羽毛边缘这类复杂对象时,传统Photosho…...

CodeSys WebVisu避坑指南:用three.js给机械臂做3D可视化,我踩过的8个坑

CodeSys WebVisu与three.js深度整合实战:机械臂3D可视化开发避坑手册 在工业自动化领域,机械臂的实时状态可视化一直是HMI开发中的难点与痛点。传统解决方案往往受限于渲染效果和交互灵活性,而基于WebGL的three.js技术栈恰好能弥补这些不足。…...

给黑帮写反侦测系统:他们在暗网给我立生祠

作为一名软件测试工程师,我从未想过,我的专业技能会让我卷入一场数字世界的道德深渊。故事始于一个匿名加密邮件,主题简洁却充满诱惑:“高薪项目:反侦测系统开发。”客户承诺丰厚报酬,并强调需要顶尖测试思…...

本地 AI 智能体落地:OpenClaw 如何稳定运行并真正提效?

最近我把 OpenClaw 作为核心自动化工具来使用了一段时间。它能让大模型直接操作电脑,跑脚本、处理文件、启动服务、执行批量任务,这种 “本地自动化” 体验非常真实。 但一开始我也被它的 “不稳定” 搞得很崩溃。 1. OpenClaw 的真正价值(…...