我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MongoDB入门6——查询(二)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MongoDB入门6——查询(二)

 3.查询中null的处理

        null的匹配非常有意思:null不仅仅会匹配到指定键的值确实等于null的文档,并且还会匹配到查询所制定键不存在的文档。例如,插入下面这三个文档:


> db.users.insert({"name":"Tom","age":20,"job":"Sales"});
> db.users.insert({"name":"Sam","age":25,"job":"Manager"});
> db.users.insert({"name":"Jim","age":25});
> db.users.insert({"name":"Sam","age":25,"job":null});

        现在我们用传统的方式来匹配job为null的文档:


> db.users.find({"job":null});

        结果如下:


{ "_id" : ObjectId("4f0714e3edb28db4864be582"), "name" : "Jim", "age" : 25 }
{ "_id" : ObjectId("4f071542edb28db4864be583"), "name" : "Sam", "age" : 25, "job" : null }

        很明显,不仅将job确实为null的文档匹配出来,而且将没有job这个键的文档匹配出来了。很多时候这并不是我们的本意。有一个$exists操作符可以来解决这个问题。先看代码:


db.users.find({"job":{"$in":[null],"$exists":true}});

        结果如下:


{ "_id" : ObjectId("4f071542edb28db4864be583"), "name" : "Sam", "age" : 25, "job" : null }

4.正则表达式

        MongoDB使用Perl兼容的正则表达式库来匹配正则表达式。正则表达式本身非常强大,有专门写这个的书,我这里不针对这个,只是简单的举个例子。例如,忽略大小写情况下匹配name为Tom的文档:


db.users.find({"name":/tom/i});

5.数组查询

        数组查询大的思路:大部分情况下,数组的每个元素都可以是对应键的值。这么说肯定不好理解,举个例子,插入下面这样一个文档:


db.food.insert({"fruit":["apple","banana","peach"]});

        现在执行下面三个查询,都会将这个文档匹配出来。


db.food.find({"fruit":"apple"});
db.food.find({"fruit":"banana"});
db.food.find({"fruit":"peach"});

        如果需要匹配fruit键的值既有apple又有banana的文档,可以使用$all匹配符。现在我们假设有下面几个文档:


{ "_id" : ObjectId("4f071a10edb28db4864be584"), "fruit" : [ "apple", "banana", "peach" ] }
{ "_id" : ObjectId("4f071c5676285076f80ca7c7"), "fruit" : [ "apple", "banana" ] }
{ "_id" : ObjectId("4f071c6076285076f80ca7c8"), "fruit" : [ "apple" ] }
{ "_id" : ObjectId("4f071ce576285076f80ca7c9"), "fruit" : [ "banana", "apple" ] } 

         执行下面的查询:


db.food.find({"fruit":{"$all":["apple","banana"]}});

        可以匹配到下面的三个文档:


{ "_id" : ObjectId("4f071a10edb28db4864be584"), "fruit" : [ "apple", "banana", "peach" ] }
{ "_id" : ObjectId("4f071c5676285076f80ca7c7"), "fruit" : [ "apple", "banana" ] }
{ "_id" : ObjectId("4f071ce576285076f80ca7c9"), "fruit" : [ "banana", "apple" ] }

        你可能会说,可以采用精确匹配整个数组的方法如下:


db.food.find({"fruit":["apple","banana"]});

        得到的结果只有一个文档:


{ "_id" : ObjectId("4f071c5676285076f80ca7c7"), "fruit" : [ "apple", "banana" ] }

        不用惊讶,这就是精确匹配,连apple和banana出现的顺序都不能调换。这种结果很显然不是很多时候我们想要的。也是为什么引进$all匹配操作符。

        还有一种匹配的语法:可以使用key.index来匹配指定键对应值(是数组的情况下)的第index+1个元素值。还是上面水果的那个例子,我们假设要匹配fruit键对应值第三个元素为peach的文档,我们可以这么写:


db.food.find({"fruit.2":"peach"});

        注意一点,数组下标是从0开始的。

        如果我们需要匹配fruit键的值数组元素个数为3个的文档,可以使用$size匹配操作符:


db.food.find({"fruit":{"$size":3}});

        这样也可以将第一个文档匹配出来。但是特别需要注意,$size匹配符是不能和其他的查询条件共同使用的。比如你按照下面写是不会有结果的:


db.food.find({"fruit":{"$gt":{"$size":2}}});

       这是不会匹配出fruit键的值数组元素个数大于2的文档。这样不会有任何查询结果的。

《MongoDB:The Definitive Guide》

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MongoDB入门6——查询(二)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL 入门教程:子查询

目录一、利用子查询进行过滤请参阅目录汇总:SQL 入门教程:面向萌新小白的零基础入门教程SELECT 语句 是 SQL 的查询。我们迄今为止所看到的所有 SELECT 语句都是简单查询,即从单个数据库表中检索数据的单条语句。查询(query)任何 SQL 语句
SQL 入门教程:子查询
2017-11-30

MySQL入门教程2 —— 输入查询及退出查询命令

确保你连接上了服务器,如在上一章节讨论的。连接上服务器并不代表选择了任何数据库,但这样就可以了。知道关于如何查询的基本知识,比马上跳至创建表、给他们装载数据并且从他们检索数据更重要。本节描述输入命令的基本原则,使用几个查询,你能尝试了解my
2022-05-27

Mongodb 插入、批量插入和分页查询性能测试

处理器名称: Intel Core i7 处理器速度: 2.5 GHz 处理器数目: 1 核总数: 4 L2 缓存(每个核): 256 KB L3 缓存: 6 MB 内存: 16 GB 测试软件环
Mongodb 插入、批量插入和分页查询性能测试
2020-11-23

SQL 入门教程:创建组合(UNION)查询

目录一、使用 UNION二、UNION 规则三、包含或取消重复的行四、对组合查询结果排序请参阅目录汇总:SQL 入门教程:面向萌新小白的零基础入门教程可用 UNION 操作符来组合数条 SQL 查询。利用 UNION,可给出多条 SELECT 语句,将它们的结
SQL 入门教程:创建组合(UNION)查询
2014-09-12

Druid 0.17入门(4)—— 数据查询方式大全

本文介绍Druid查询数据的方式,首先我们保证数据已经成功载入。Druid查询基于HTTP,Druid提供了查询视图,并对结果进行了格式化。Druid提供了三种查询方式,SQL,原生JSON,CURL。一、SQL查询我们用wiki的数据为例查询10条最多的页面
Druid 0.17入门(4)—— 数据查询方式大全
2021-01-31

MongoDB(四):数据类型、插入文档、查询文档

1. 数据类型 MongoDB支持许多数据类型。字符串 - 这是用于存储数据的最常用的数据类型。MongoDB中的字符串必须为UTF-8。整型 - 此类型用于存储数值。 整数可以是32位或64位,具体取决于服务器。布尔类型 - 此类型用于存储布尔值(true
MongoDB(四):数据类型、插入文档、查询文档
2020-04-16

【MySQL新手入门系列四】:手把手教你MySQL数据查询由入门到学徒

SQL语言是与数据库交互的机制,是关系型数据库的标准语言。SQL语言可以用于创建、修改和查询关系数据库。SQL的SELECT语句是最重要的命令之一,用于从指定表中查询数据。在此博客中,我们将进一步了解SELECT语句以及WHERE子句以及它
2023-08-17

网络安全从入门到精通 (第二章-6) 后端基础PHP—表单验证

本文内容:什么是表单?如何创建一个表单:接收并验证:PHP和数据库交互1,什么是表单?  表单在网页中主要负责数据采集。  表单由三部分组成:    表单标签:这里面包含了处理表单数据所用动态脚本的URL,以及数据提交到服务器的方法。    表单域:包含了文本
网络安全从入门到精通 (第二章-6) 后端基础PHP—表单验证
2021-06-03

MySQL入门教程7 —— 常用数据库查询的示例

下面是一些学习如何用MySQL解决一些常见问题的例子。在一些例子中,使用数据库表“shop”来储存某个商人(经销商)的每件物品(物品号)的价格。假定每个商人对每项物品有一个固定价格,那么(物品,商人)即为该记录的主关键字。启动命令行工具my
2022-05-12

【第3天】MYSQL快速入门-高级查询(SQL 小虚竹)

回城传送–》《100天精通MYSQL从入门到就业》 文章目录 零、前言 一、练习题目 二、SQL思路 计算函数:SQL16 查找GPA最高值 初始化数据 解法
2023-08-28

编程热搜

目录