当前位置: 首页 > 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条文档
http://www.lryc.cn/news/213508.html

相关文章:

  • 41.排序练习题(王道2023数据结构第8章综合练习)
  • python爬虫,如何在代理的IP被封后立刻换下一个IP继续任务?
  • 小程序开发——小程序项目的配置与生命周期
  • C语言之用指针交换两个数
  • Day 48 动态规划 part14
  • 目标检测与图像识别分类的区别?
  • 群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新)
  • 博客摘录「 MySQL不区分大小写设置」2023年10月31日
  • 【UE5】如何在UE5.1中创建级联粒子系统
  • SpringCloud(五) Eureka与Nacos的区别
  • C语言 DAY07:预编译,宏,选择性编译,库(静态库,动态库)
  • [EFI]asus strix b760-i 13900F电脑 Hackintosh 黑苹果efi引导文件
  • 力扣383.赎金信
  • CORS的原理以及在Node.js中的使用
  • kotlin实现单例模式
  • 【Java】LinkedList 集合
  • MySQL-Galera-Cluster集群详细介绍
  • JavaScript从入门到精通系列第二十六篇:详解JavaScript中的Math对象
  • u盘直接拔出文件丢失怎么找回?u盘文件恢复办法分享!
  • rust学习-LinkedList
  • 搭上直播快车,文旅迎来了更大爆发期?
  • 【智能座舱系列】- 深度解密小米Hyper OS,华为HarmonyOS区别
  • kafka-consumer-groups.sh
  • 数据仓库-拉链表
  • 【Docker】一些可以直接用的Docker环境
  • Unity2D中瓦片地图的创建与绘制教程
  • 现代的简洁,诠释轻奢的精致!福州中宅装饰,福州装修
  • 运用ChatGPT辅助新手学习躺赢者PRO飞控二次开发示例(2023年10月28日)
  • 【Java】HashCode方法重写注意事项
  • 039-第三代软件开发-PDF阅读器