首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mongoDB 文档查询

在关系型数据库中,可以实现基于表上各种各样的查询,以及通过投影来返回指定的列。对于NoSQL mongoDB而言,所有能够在单表上完成的查询,在mongoDB中也可以完全胜任。...除此之外,由于mongoDB支持基于文档嵌套以及数组,因此mongoDB也可以实现基于嵌套文档和数组的查询。具体见下文描述。...预备热身 Linux下快速安装MongoDB Windows平台下安装MongoDB mongoDB 启动与停止 mongo shell连接到mongoDB及shell提示符下执行js脚本...mongoDB简介及关键特性 SQL与mongoDB对比及映射 一、查询语法 db.collection.find( , )...} ) //查询数组内嵌文档 //查询数组points内嵌文档键points的值小于等于55的文档,此处未指定数组下标 db.users.find( { 'points.points

3.1K20

MongoDB文档查询操作

MongoDB文档查询 1、语法 2、对比语法 3、AND 4、OR 5、AND与OR联合 6、数据中查询 7、模糊查询 8、排序 9、分页 10、总条数 11、去重 12、指定返回字段 1、语法...查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。...2、对比语法 如果你熟悉常规的 SQL 数据,通过下表可以更好的理解 MongoDB 的条件语句查询: 先查询下collections中的数据 让数据友好显示: db.users.find().pretty...() 我们查询年龄为24的文档数据 db.users.find({age:24}) 查询年龄小于29岁的数据 db.users.find({age:{$lt:29}}) 查询年龄小于等于29岁的数据...')' > db.集合名称.find({"age": {$gt:50}, $or: [{"name": "编程不良人"},{"name": "MongoDB"}]}).pretty(); 6、数据中查询

1.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

MongoDB文档查询操作(一)

上篇文章我们主要介绍了MongoDB的修改操作,本文我们来看看查询操作。...本文是MongoDB系列的第五篇文章,了解前面的文章有助于更好的理解本文: ---- find方法再探 find方法是很重要的一个查询方法,我们在前面也已经使用过多次了,一般情况下我们调用的是: find...如果有查询条件,我们传入查询条件即可,查询条件也是一个文档,如下表示查询x为1的文档: db.sang_collect.find({x:1}) 如果查询条件文档中有多个字段,多个字段之间的关系是AND,...如下表示查询x为1并且y为99的文档: db.sang_collect.find({x:1,y:99}) 默认情况下,每次查询都会返回文档中所有的key/value对,我们也可以自定义返回的字段,如下表示只返回...《MongoDB权威指南第2版》

84260

MongoDB文档查询操作(三)

关于MongoDB中的查询,我们已经连着介绍了两篇文章了,本文我们来介绍另外一个查询概念游标。 本文是MongoDB系列的第七篇文章,了解前面的文章有助于更好的理解本文。...()方法,也有next()方法,这两个方法结合可以用来遍历结果,如下: while(cursor.hasNext()){ print(cursor.next()) } next()方法可以获取查询到的每一个文档.../* 2 */ { "_id" : ObjectId("59f299579babb96c21ddc9e9"), "x" : 1.0, "y" : 999.0 } 如果我只想获取文档中的某一个字段...,直接一条一条的返回查询到的数据,这100条或者4MB数据全部被返回之后,shell才会再次发起请求向MongoDB要数据。...好了,MongoDB中的查询我们就说到这里,小伙伴们有问题欢迎留言讨论。 参考资料: 1.《MongoDB权威指南第2版》

1.2K40

MongoDB文档查询操作(二)

上篇文章我们对MongoDB中的查询操作做了简单介绍,本文我们继续来看更丰富的查询操作。...本文是MongoDB系列的第六篇文章,了解前面的文章有助于更好的理解本文: ---- null null的查询稍微有点不同,假如我想查询z为null的数据,如下: db.sang_collect.find...({z:null}) 这样不仅会查出z为null的文档,也会查出所有没有z字段的文档,如果只想查询z为null的字段,那就再多加一个条件,判断一下z这个字段存在不,如下: db.sang_collect.find...嵌套文档查询 嵌套文档有两种查询方式,比如我的数据如下: { "_id" : ObjectId("59f20c9b7b00f982986c669f"), "x" : 1.0, "...好了,MongoDB中的查询操作还是非常丰富的,本文我们先说到这里,下篇文章我们介绍游标,小伙伴们有问题欢迎留言讨论。 参考资料: 1.《MongoDB权威指南第2版》

1.2K30

MongoDB(10)- 查询嵌套文档

"postcard", qty: 45, size: { h: 10, w: 15.25, uom: "cm" }, status: "A" } ]); 后面的栗子都会用到这里的测试数据 精确匹配嵌套文档...换了个字段顺序就查不到同一条文档查询嵌套字段 要在嵌入/嵌套文档中的字段上指定查询条件,语法格式如下 "field.nestedField" 跟 JSON 取值一样,用 ...."paper", "qty" : 100, "size" : { "h" : 8.5, "w" : 11, "uom" : "in" }, "status" : "D" } size 字段值是一个文档...,找到嵌套文档的 h 字段值等于 in 的所有文档 栗子二:嵌套字段结合单个查询条件操作符 > db.inventory.find( { "size.h": { $lt: 15 } } ) { "_id...,找到嵌套文档的 h 字段值小于 15 的所有文档 栗子三:多个不同嵌套字段结合 and 操作 > db.inventory.find( { "size.h": { $lt: 15 }, "size.uom

2K20

MongoDB查询(数组、内嵌文档和$where)

如果是精确匹配的方式,MongoDB的处理方式是完全相同的匹配,即顺序与数量都要一致,上述中第一条文档查询条件的顺序不一致,第三条文档查询条件文档多一个元素,都没有被匹配成功!...---- 【查询内嵌文档查询文档有两种方式,一种是完全匹查询,另一种是针对键值对查询!内嵌文档的完全匹配查询和数组的完全匹配查询一样,内嵌文档内键值对的数量,顺序都必须一致才会匹配,如下例: ?...针对内嵌文档特定键值对的查询是最常用的!通过点表示法来精确表示内嵌文档的键: ? 我们看,这样查询,所有有效文档均被查询到了!通过点表示法,可以表示深入到内嵌文档内部的键!...但如果实际中真的遇到一种情况无法用上述方式实现时,不用慌,MongoDB为我们提供了终极武器:"$where",用他可以执行任意JavaScript作为查询的一部分!...我们可以看出,使用"$where"其实就是写了一个javascript函数,MongoDB查询时,会将每个文档转换成一个javascript对象,然后扔到这个函数中去执行,通过返回结果来判断其是否匹配

5.9K20

MongoDB(12)- 查询嵌入文档的数组

查询 instock 数组中包含 { warehouse: "A", qty: 5 } 的所有文档 > db.inventory.find( { "instock": { warehouse: "...,如果不知道文档的准确索引值,只能按照以下格式 数组字段名.文档字段名 instock.qty 使用数组索引查询嵌入文档中的字段 上面的栗子是直接根据字段名查找 在 instock 数组中,第一个元素包含字段...(多个)查询条件 栗子一 找到在 instock 数组中【至少有一个嵌入文档包含 qty > 10,以及至少有一个嵌入文档(但不一定是同一个嵌入文档)包含 qty ≤20 】的文档 > db.inventory.find...: "planner", "instock" : [ { "warehouse" : "A", "qty" : 40 }, { "warehouse" : "B", "qty" : 5 } ] } 在文档数组中单个嵌套文档满足多个查询条件...前言 上面的栗子都是单个嵌套文档或多个嵌套文档满足多个查询条件即可 如果想确保单个嵌套文档必须同时满足多个查询条件呢?

4.5K10

MongoDB(9)- 文档查询操作之 find() 的简单入门

find() MongoDB查询文档使用 find() find() 方法以非结构化的方式来显示所要查询文档 语法格式 db.collection.find(query, projection)...query:可选项,设置查询操作符指定查询条件 projection :可选项,指定要在与 query 匹配的文档中返回的字段,如果忽略此选项则返回所有字段 pretty() 为了查看文档的格式更加直观美丽..."uom" : "cm" }, "status" : "A" } 注意:findOne() 是没有的跟 pretty() 方法的 findOne() 和 find() 的都是查询文档...,但是只返回匹配查询条件成功的第一个文档 语法格式 db.collection.findOne(query, projection) 查询条件 MongoDB 支持查询条件操作符,下表为 MongoDB...,and 加 or 的操作 查询文档选择集合中 status 为“A”、qty小于($lt)30或 item 以字符 p 开头的所有文档 db.inventory.find( { status

84010

技术干货| 一文读懂如何查询 MongoDB 文档

点击下方公众号关注并分享获取 MongoDB 最新资讯 一.查询文档 本段提供了使用 mongo shell中 db.collection.find() 方法查询的案例。...上述操作对应如下 SQL :SELECT * FROM inventory WHERE status in ("A", "D") 有关 MongoDB 查询运算符的完整列表,请参考查询和映射操作符。...其它的方法 下面的方法也可以从集合中查询文档: db.collection.findOne在聚合管道中,$match 管道阶段提供了 MongoDB查询过滤。...默认情况下,MongoDB查询语句返回匹配到文档的所有字段,为了限制 MongoDB 返回给应用的数据,可以通过 projection 文档来指定或限制返回的字段。...参考:Query Documents 查询导航链接 查询文档 查询嵌套文档 查询数组 查询数组中嵌套文档 查询返回的字段 关于译者:张芷嘉 MongoDB 中文社区翻译小组成员; MongoDB 中文用户文档

3.9K10

mongodb联表查询_mongodb聚合查询

在使用MongoDB存储数据的时候,我们查询的时候,有时候难免会需要进行连表查询。但是MongoDB本身是非关系性数据库,连表查询,很多时候,需要我们自己在代码里手工操作。...但是从 MongoDB 3.2 版本过后,我们可以使用 $lookup 进行连表查询。下面就简单介绍一下 MongoDB 的 $lookup 的简单使用。   ..."$u.name" } }, { $project: { _id: 1, product: 1, money: 1, name: 1 } }]); 虽然在 MongoDB...3.2 后我们能够进行连表查询了,方便了很多。...但是其实 MongoDB 本身是非关系性数据库。如果需要进行频繁的这种连表查询,我们可以考虑优化我们的数据库表。比如在订单表里面,每一条的订单记录都把我们的用户信息放进去。

2.7K20

mongoDB 文档插入

mongoDB文档插入与SQL表insert方式基本相同。...如果已经存在,则会在现有的集合内增加新文档。而且插入的文档可以与集合上的其他文档使用不同的键或键值类型。本文主要描述mongoDB文档插入,供大家参考。...脚本 mongoDB简介及关键特性 SQL与mongoDB对比及映射 一、文档插入语法 db.collection.insertOne(obj, ) 插入单个文档到一个集合...则自动创建该集合,否则直接插入文档 mongoDB中所有的插入操作都属于单个文档级别的原子性操作,即相当于关系型数据库的行级锁 mongoDB文档插入的时候,如果未显示指定_id列,则会自动添加该列...57ece37fce13bb2bef55fb0e”) ] } db.users.find({“_id”:ObjectId(“57ece37fce13bb2bef55fb0d”)}) //基于ObjectId查询特定文档

94930
领券