mongo常用操作符及查询例子
最佳答案 问答题库628位专家为你答疑解惑
比较操作符:
$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 查询操作符及其示例:
-
比较操作符:
-
$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 } })
-
-
逻辑操作符:
-
$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 } } ] })
-
-
数组操作符:
-
$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 查询操作符的示例:
-
元素操作符:
-
$exists
:匹配包含指定字段的文档。db.collection.find({ field_name: { $exists: true } })
-
$type
:匹配指定数据类型的字段。db.collection.find({ field_name: { $type: "string" } })
-
-
正则表达式操作符:
-
$regex
:匹配字段值符合指定正则表达式的文档。db.collection.find({ title: { $regex: /pattern/i } })
-
-
文本搜索操作符:
-
$text
:执行全文本搜索。db.collection.find({ $text: { $search: "search term" } })
-
$meta
:获取文本搜索得分。db.collection.find({ $text: { $search: "search term" } }, { score: { $meta: "textScore" } })
-
-
元素更新操作符:
-
$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" } })
-
-
查询修改操作符:
-
$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条文档
-
99%的人还看了
相似问题
- django ModelSerializer自定义显示字段
- 替换sql,某个字段特定容
- Java之反射获取和赋值字段
- java mybatisplus generator 修改字段类型
- 使用用户代理字段进行浏览器检测(判断页面运行环境)
- js数组操作——对象数组根据某个相同的字段分组
- spring boot加mybatis puls实现,在新增/修改时,对某些字段进行处理,使用的@TableField()
- 【IDEA 使用easyAPI、easyYapi、Apifox helper等插件时,导出接口文档缺少代码字段注释的相关内容、校验规则的解决方法】
- mysql取出组内按照某时间最新一条数据的其他字段
- 基于geotools24.0的创建自动增长主键id字段的方法
猜你感兴趣
版权申明
本文"mongo常用操作符及查询例子":http://eshow365.cn/6-27998-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!