MongoDB文档查询操作(二)
上篇文章我们对MongoDB中的查询操作做了简单介绍,本文我们继续来看更丰富的查询操作。
本文是MongoDB系列的第六篇文章,了解前面的文章有助于更好的理解本文:
null
null的查询稍微有点不同,假如我想查询z为null的数据,如下:
db.sang_collect.find({z:null})
这样不仅会查出z为null的文档,也会查出所有没有z字段的文档,如果只想查询z为null的字段,那就再多加一个条件,判断一下z这个字段存在不,如下:
db.sang_collect.find({z:{$in:[null],$exists:true}})
正则表达式查询
使用正则表达式查询我们在前面也已经介绍过了,这里的正则表达式语法和JavaScript中的正则表达式语法一致,比如查询所有key为x,value以hello开始的文档且不区分大小写:
db.sang_collec.find({x:/^(hello)(.[a-zA-Z0-9])+/i})
数组查询
假设我有一个数据集如下:
{
"_id" : ObjectId("59f1ad41e26b36b25bc605ae"),
"books" : [
"三国演义",
"红楼梦",
"水浒传"
]
}
查询books中含有三国演义的文档,如下:
db.sang_collect.find({books:"三国演义"})
如果要查询既有三国演义又有红楼梦的文档,可以使用$all,如下:
db.sang_collect.find({books:{$all:["三国演义","红楼梦"]}})
当然我们也可以使用精确匹配,比如查询books为"三国演义","红楼梦", "水浒传"
的数据,如下:
db.sang_collect.find({books:["三国演义","红楼梦", "水浒传"]})
不过这种就会一对一的精确匹配。
也可以按照下标匹配,比如我想查询数组中下标为2的项的为"水浒传"
的文档,如下:
db.sang_collect.find({"books.2":"水浒传"})
也可以按照数组长度来查询,比如我想查询数组长度为3的文档:
db.sang_collect.find({books:{$size:3}})
如果想查询数组中的前两条数据,可以使用$slice,如下:
db.sang_collect.find({},{books:{$slice:2}})
注意这里要写在find的第二个参数的位置。2表示数组中前两个元素,-2表示从后往前数两个元素。也可以截取数组中间的元素,比如查询数组的第二个到第四个元素:
db.sang_collect.find({},{books:{$slice:[1,3]}})
数组中的与的问题也值得说一下,假设我有如下数据:
{
"_id" : ObjectId("59f208bc7b00f982986c669c"),
"x" : [
5.0,
25.0
]
}
我想将数组中value取值在(10,20)之间的文档获取到,如下操作:
db.sang_collect.find({x:{$lt:20,$gt:10}})
此时上面这个文档虽然不满足条件却依然被查找出来了,因为5<20
,而25>10
,要解决这个问题,我们可以使用$elemMatch,如下:
db.sang_collect.find({x:{$elemMatch:{$lt:20,$gt:10}}})
$elemMatch要求MongoDB同时使用查询条件中的两个语句与一个数组元素进行比较。
嵌套文档查询
嵌套文档有两种查询方式,比如我的数据如下:
{
"_id" : ObjectId("59f20c9b7b00f982986c669f"),
"x" : 1.0,
"y" : {
"z" : 2.0,
"k" : 3.0
}
}
想要查询上面这个文档,我的查询语句如下:
db.sang_collect.find({y:{z:2,k:3}})
但是这种写法要求严格匹配,顺序都不能变,假如写成了db.sang_collect.find({y:{k:3,z:2}})
,就匹配不到了,因此这种方法不够灵活,我们一般推荐的是下面这种写法:
db.sang_collect.find({"y.z":2,"y.k":3})
这种写法可以任意颠倒顺序。
好了,MongoDB中的查询操作还是非常丰富的,本文我们先说到这里,下篇文章我们介绍游标,小伙伴们有问题欢迎留言讨论。
参考资料:
1.《MongoDB权威指南第2版》
- 【翻译】在Visual Studio中使用Asp.Net Core MVC创建你的第一个Web API应用(一)
- 基于JQuery EasyUI的WebMVC控件封装(含源码)
- Android系统源码分析-JNI
- EntityFrameWork实现部分字段获取和修改(含源码)
- 基于Ado.Net的日志组件
- Do you kown Asp.Net Core -- 配置Kestrel端口
- 【翻译】在Visual Studio中使用Asp.Net Core MVC创建第一个Web Api应用(二)
- 微信快速开发框架(一)-- 对微信公众平台开发的消息处理
- 微信快速开发框架(二) -- 快速开发微信公众平台框架---简介
- LayoutInflater 布局渲染工具原理分析
- 使用Keras在训练深度学习模型时监控性能指标
- 微信快速开发框架(四)-- 体验微信公众平台快速开发框架
- AsyncTask源码解析
- 微信快速开发框架(五)-- 利用快速开发框架,快速搭建微信浏览博客园首页文章
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- zabbix微信报警设置
- C#中调用python
- Emgucv视频处理--进阶篇
- C#中Lambda表达式总结
- [打造自己的监控系统]使用Django批量监控Oracle长会话
- C# ref实例讲解
- [Oracle 故障处理]记一次undo表空间使用率99%的问题
- C# 队列(Queue)
- 记住没:永远不要在 MySQL 中使用 UTF-8!
- C#多线程委托ParameterizedThreadStart应用
- [Python爬虫]使用Selenium操作浏览器订购火车票
- IDEA多线程调试
- 为什么wait和notify方法要在同步块中调用?
- 一文说清楚Mysql Innodb的B+树索引原理及其推理过程
- [Oracle数据泵全解析]expdp交互式命令行模式命令