千家信息网

MongoDB的查询

发表于:2025-11-16 作者:千家信息网编辑
千家信息网最后更新 2025年11月16日,MongoDB使用find来查询,不指定任何参数说明是对整个集合的文档查询。find查询指定返回的键有时并不需要将文档中所有键值对都返回,可以通过find(或者findOne)的第二个参数来制定想要的
千家信息网最后更新 2025年11月16日MongoDB的查询

MongoDB使用find来查询,不指定任何参数说明是对整个集合的文档查询。

  1. find查询

指定返回的键

有时并不需要将文档中所有键值对都返回,可以通过find(或者findOne)的第二个参数来制定想要的键,这样即会节省传输的数据量,又能节省客户端解码文档的时间和内存消耗。

例如:

> db.people.find()

{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,

"enemies" : 2 }

{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }

>

如果只对name和age感兴趣,可以这样查询:

> db.people.find({"name":"joe","age":21})

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

>

但是"_id"总是被返回,即便没有指定。

可以使用第二个参数来剔除查询结果中的某个键值对,例如,如果不希望显示"friends" : 32的键值对:

> db.people.find({},{"friends":0})

{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "enemies" : 2 }

{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }

>

也可以用来防止返回"_id":

> db.people.find({"age":21},{"_id":0})

{ "name" : "joe", "age" : 21 }

2、查询条件

查询不仅能精确匹配,还能匹配更加复杂的条件,比如范围,OR子句或者取反。

2.1、查询条件

查询条件的比较操作符:

"$lt" 对应 <

"$lte" 对应<=

"$gt" 对应>

"$gte" 对应>=

"$ne" 对应"不相等"

> db.people.find({"age":{"$gte":30,"$lte":50}})

{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }

> db.people.find({"age":{"$ne":65}})

{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,

"enemies" : 2 }

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }

"$ne" 用于所有数据的类型。

2.1、OR查询

有两种方式进行OR查询。

"$in":可以用于查询一个键的多个值;

"$or":完成多个键值的任意给定值。

2.1.1"$in"

对于单一键要是有多个值与其匹配的话,就要用"$in"加一个条件数组:

> db.people.find({"age":{"$in":[21,49,65]}})

{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d08fbd0eb7b5f5718da82c"), "name" : "joe", "age" : 49 }

>

"$in"非常灵活,可以指定不同类型的条件和值:

> db.people.insert({"age":"kkk"})

WriteResult({ "nInserted" : 1 })

> db.people.find({"age":{"$in":[21,"kkk"]}})

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d334cbb174be28d017c1a6"), "age" : "kkk" }

>

要是"$in"对应的数组只有一个值,那么和直接匹配这个值的效果是一样的。

> db.people.find({"age":{"$in":[21]}})

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

> db.people.find({"age":21})

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

>

2.1.1"$nin"

和"$in"相对的是"$nin",将返回与数组中所有条件都不匹配的文档:

> db.people.find({"age":{"$nin":[21,49,65]}})

{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,

"enemies" : 2 }

{ "_id" : ObjectId("54d334cbb174be28d017c1a6"), "age" : "kkk" }

>

2.1.1"$or"

"$or"接受一个包含所有可能条件的数组作为参数:

> db.people.find({"$or":[{"age":"kkk"},{"friends":32}]})

{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,

"enemies" : 2 }

{ "_id" : ObjectId("54d334cbb174be28d017c1a6"), "age" : "kkk" }

>

同时"$or"可以包含其他条件句:

> db.people.find({"$or":[{"age":"kkk"},{"friends":32},{"age":{"$in":[21,65]}}]})


{ "_id" : ObjectId("54d08a1d0eb7b5f5718da828"), "name" : "joe", "friends" : 32,

"enemies" : 2 }

{ "_id" : ObjectId("54d08f7f0eb7b5f5718da82a"), "name" : "joe", "age" : 65 }

{ "_id" : ObjectId("54d08fb70eb7b5f5718da82b"), "name" : "joe", "age" : 21 }

{ "_id" : ObjectId("54d334cbb174be28d017c1a6"), "age" : "kkk" }

>

AND型的查询,总是尽可能地用最少的条件来限定结果的范围;而OR型的查询则相反,第一个条件尽可能地匹配更多的文档,这样才是最高效的。


查询 条件 文档 参数 数组 多个 尽可能 数据 类型 结果 范围 要是 不同 复杂 精确 兴趣 内存 只有 可以通过 同时 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 苹果id老是显示无法连接服务器 宽城区通用网络技术咨询质量服务 血液系统疾病数据库 广州拉手网络技术有限公司 软件开发专业买什么笔记本推荐 文件服务器安全设施 寺庙宣传网络安全知识简报 达梦数据库text作为查询条件 广州融增网络技术是什么 南京数据库营销专员招聘 为什么数据要迁移新服务器 linux服务器监控软件 安徽数据库日志审计公司 计算机大赛网络技术 91助手 备份程序数据库 环境影响数据库 杭州轲洛网络技术有限公司 全球网络安全hcc大会 好写软件开发论文 凤凰天气预报软件开发 加载数据库的驱动名 紫光服务器进入raid 联想服务器通电不开机 车载网络安全性怎么选 重庆市逆转网络技术有限责任公司 网络怎么连接不上服务器 泰安便民平台软件开发系统 委托应用软件开发付款条款 人员信息数据库及表实例 如何设置vpn服务器
0