MongoDB数据查询详解
查询全部
db.infos.find();
db.infos.find({"url":"www.baidu.com"});
id不要显示出来
db.infos.find({"url":"www.baidu.com"},{"_id":0});
关系运算
大于 $gt
小于 $lt
大于等于 $gte
小于等于 $lte
不等于 $ne
准备测试数据
db.students.insert({"name":"张三","sex":"男","age":19,"score":89,"address":"海淀区"});
db.students.insert({"name":"李四","sex":"女","age":20,"score":59,"address":"朝阳区"});
db.students.insert({"name":"王五","sex":"女","age":19,"score":99,"address":"西城区"});
db.students.insert({"name":"赵六","sex":"男","age":20,"score":100,"address":"东城区"});
db.students.insert({"name":"孙七","sex":"男","age":19,"score":20,"address":"海淀区"});
db.students.insert({"name":"王八","sex":"女","age":21,"score":0,"address":"海淀区"});
db.students.insert({"name":"刘九","sex":"男","age":19,"score":70,"address":"朝阳区"});
db.students.insert({"name":"钱十","sex":"女","age":21,"score":56,"address":"西城区"});
查询姓名为张三的学生的数据
db.students.find({"name":"张三"});
查询性别是男的学生的信息
db.students.find({"sex":"男"});
查询年龄大于19岁的学生
db.students.find({"age":{"$gt":19}});
查询成绩大于等于60分的学生
db.students.find({"score":{"$gte":60}});
查询姓名不是王五的信息
db.students.find({"name":{"$ne":"王五"}});
逻辑运算
三种类型
与 $and
或 $or
非 $nor
查询年龄在19到20之间的数据
db.students.find({"age":{"$gte":19,"$lte":20}});
查询年龄不是19的数据
db.students.find({"age":{"$ne":19}});
查询年龄大于19岁,或者成绩大于90分的学生的信息
db.students.find({
"$or": [
{"age":{"$gt":19}},
{"score":{"$gt":90}}
]
});
查询年龄不大于19或者成绩不大于90的学生的信息
db.students.find({
"$nor": [
{"age":{"$gt":19}},
{"score":{"$gt":90}}
]
});
模运算
查询年龄模20余1的数据,也就是21或者41的学生信息
db.students.find({"age":{"$mod":[20,1]}});
范围查询
$in 、 $nin
查询姓名是“张三”、“李四”、“王五”的信息。
多个数据用数组表示。
db.students.find({"name":{"$in":["张三","李四","王五"]}})
db.students.find({"name":{"$nin":["张三","李四","王五"]}})
数组查询
mongoDB支持数组保存,也支持数组匹配查询。
再插入一些数据
db.students.insert({"name":"大神 - A","sex":"女","age":21,"score":0,"address":"海淀区","course":["语文","数学","英语","音乐","政治"]});
db.students.insert({"name":"大神 - B","sex":"男","age":19,"score":70,"address":"朝阳区","course":["语文","数学"]});
db.students.insert({"name":"大神 - C","sex":"女","age":21,"score":56,"address":"西城区","course":["语文","数学","英语"]});
db.students.insert({"name":"大神 - D","sex":"女","age":21,"score":0,"address":"海淀区","course":["语文","数学","英语"]});
db.students.insert({"name":"大神 - E","sex":"男","age":19,"score":70,"address":"朝阳区","course":["英语","音乐"]});
db.students.insert({"name":"大神 - F","sex":"女","age":21,"score":56,"address":"西城区","course":["语文","数学","英语","音乐"]});
查询同时参加语文和数学课程的学生
db.students.find({"course":{"$all":["语文","数学"]}});
$all 可以用在数组查询上,也可以用于一个数据的匹配上。
查询地址是“海淀区”的信息。
db.students.find({"address":{"$all":["海淀区"]}});
范例:查询课程数组中第二个内容是音乐的用户。使用索引。
db.getCollection('students').find({"course.1":"音乐"})
范例:查询只参加两门课程的学生
db.getCollection('students').find({"course":{"$size":2}})
范例:返回年龄为19岁的学生信息,课程信息只返回两条。
db.getCollection('students').find({"age":21},{"course":{"$slice":2}})
也可以设置负数,取出后两门的数据。
db.getCollection('students').find({"age":21},{"course":{"$slice":-2}})
或者只取出中间部分的信息。
db.getCollection('students').find({"age":21},{"course":{"$slice":[1,2]}})
嵌套集合运算
再增加一些数据
db.students.insert({"name":"高大拿 - A","sex":"女","age":21,"score":0,"address":"海淀区","course":["语文","数学","英语","音乐","政治"],
"parents":
[{"name":"高大拿 - A(父亲)","age":50,"job":"工人"},
{"name":"高大拿 - A(母亲)","age":46,"job":"职员"}]
});
db.students.insert({"name":"高大拿 - B","sex":"男","age":19,"score":70,"address":"朝阳区","course":["语文","数学"],
"parents":
[{"name":"高大拿 - B(父亲)","age":50,"job":"处长"},
{"name":"高大拿 - B(母亲)","age":46,"job":"局长"}]
});
db.students.insert({"name":"高大拿 - C","sex":"女","age":21,"score":56,"address":"西城区","course":["语文","数学","英语"],
"parents":
[{"name":"高大拿 - C(父亲)","age":50,"job":"工人"},
{"name":"高大拿 - C(母亲)","age":46,"job":"局长"}]
});
范例:查询年龄是19,父母中有职务是局长的数据
db.getCollection('students').find({
"$and":[
{"age":19},
{"parents":{"$elemMatch":{"job":"局长"}}}
]
})
判断某个字段是否存在
通过 $exists来判断某个字段是否存在
范例:查询具有parents成员的数据
db.getCollection('students').find({
"parents":{"$exists":true}
})
范例:查询不具有course成员的数据
db.students.find({
"course":{"$exists":false}
})
条件过滤
$where
db.students.find({
"$where":"this.age>20"
})
db.students.find("this.age>21");
db.students.find(function() {
return this.age > 20
});
db.students.find({"$where":function() {
return this.age > 20
}});
多条件查询
db.students.find({"$and":[
{"$where":"this.age>20"},
{"$where":"this.score>20"}
]});
这里会将MongoDB的BSON格式变为JavaScript格式,不方便使用数据库索引机制。
正则运算
范例:查询以“张”开头的姓名
db.students.find({"name":/^张/});
正则不要加引号了。
范例:查询姓名有“A”的数据,加上i表示不区分大小写
db.students.find({"name":/a/i});
db.students.find({"name":{"$regex":/a/i}});
除了可以单个查询之外,还可以进行数组查询。
范例:查询数组数据中包含语文的数据
db.students.find({"course":{"$regex":/语文/}});
数据排序
通过sort()函数,升序是1,将序-1。1和-1不要加引号。
范例:按照成绩排序,成绩高的排在前面
db.students.find({"course":{"$regex":/语文/}}).sort({"score":-1});
范例:自然排序,按照数据保存的先后顺序排序
db.students.find({"course":{"$regex":/语文/}}).sort({"$natural":-1});
分页显示
两个操作函数 ⏰
skip(n):表示跨过多少数据行
limit(n):表示取出多少行
范例:分页获取数据(第一页,skip(0),limit(5)。第二页,skip(5),limit(5))
db.students.find().skip(5).limit(5);
MongoDB数据查询详解的更多相关文章
- Hive 学习之路(八)—— Hive 数据查询详解
一.数据准备 为了演示查询操作,这里需要预先创建三张表,并加载测试数据. 数据文件emp.txt和dept.txt可以从本仓库的resources目录下载. 1.1 员工表 -- 建表语句 CREAT ...
- Hive 系列(八)—— Hive 数据查询详解
一.数据准备 为了演示查询操作,这里需要预先创建三张表,并加载测试数据. 数据文件 emp.txt 和 dept.txt 可以从本仓库的resources 目录下载. 1.1 员工表 -- 建表语句 ...
- 入门大数据---Hive数据查询详解
一.数据准备 为了演示查询操作,这里需要预先创建三张表,并加载测试数据. 数据文件 emp.txt 和 dept.txt 可以从本仓库的resources 目录下载. 1.1 员工表 -- 建表语句 ...
- django orm 数据查询详解
一 在django里面创建模型 from django.db import models class Blog(models.Model): name = models.CharField(max_l ...
- MongoDB状态查询详解:db.serverStatus()
https://www.2cto.com/database/201501/370191.html
- ElasticSearch第四步-查询详解
ElasticSearch系列学习 ElasticSearch第一步-环境配置 ElasticSearch第二步-CRUD之Sense ElasticSearch第三步-中文分词 ElasticSea ...
- ContentProvider数据访问详解
ContentProvider数据访问详解 Android官方指出的数据存储方式总共有五种:Shared Preferences.网络存储.文件存储.外储存储.SQLite,这些存储方式一般都只是在一 ...
- Solr安装入门、查询详解
Solr安装入门:http://www.importnew.com/12607.html 查询详解:http://www.360doc.com/content/14/0306/18/203871_35 ...
- ThinkPHP视图查询详解
ThinkPHP视图查询详解 参考http://www.jb51.net/article/51674.htm 这篇文章主要介绍了ThinkPHP视图查询,需要的朋友可以参考下 ThinkP ...
随机推荐
- bzoj3713: [PA2014]Iloczyn(乱搞)
3713: [PA2014]Iloczyn 题目:传送门 题解: 随手一发水题x2 直接离线啊,斐波那契到了第五十个就炒鸡大了 代码: #include<cstdio> #include& ...
- 谷歌开源可视化工具Facets,将用于人+AI协作项目研究——无非就是一个用于特征工程探索的绘图工具集,pandas可以做的
见:http://www.infoq.com/cn/news/2017/07/goole-sight-facets-ai https://github.com/PAIR-code/facets/blo ...
- 双系统下Ubuntu时间不准问题
运行命令: sudo apt-get install ntpdate sudo ntpdate time.windows.com sudo hwclock --localtime --systohc ...
- Java NIO(六)选择器
前言 Selector选择器是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件.这样使得一个单独的线程可以管理多个Channel,从而管理多个网络连接.选择 ...
- Android 多线程下载 显示进度 速度
功能要求:从网络下载一APK应用,显示下载速度.进度,并安装应用. 运行效果图: 工程结构图: 很简单,就一个activity,一个更新UI的线程,一个下载线程加个文件处理类 主要代码: /** *多 ...
- heavy dark--读《《暗时间》》
本书名为<<暗时间>>,个人觉得是一个非常好的名字:1.迷茫的大学生有多少的业余时间,但又浪费多少的业余时间,浪费的这莫多时间就如同人在黑夜中一样,大脑是在休息的状态.这是第一 ...
- JSTL教程 [JSP 标准标记库]
JSTL教程- - JSP 标准标记库(JSP Standard Tag Library,JSTL)是一个实现 Web 应用程序中常见的通用功能的定制标记库集,这些功能包括迭代和条件判断.数据管理格式 ...
- Type system-Type checking
类型系统的属性: 1.结构属性: 2.规则属性:类型系统定义了一套规则(内部数据的访问规则.函数的访问规则.类型的比较与转化规则),以供编译和运行时进行检查. In programming langu ...
- Imperative programming
In computer science, imperative programming is a programming paradigm that uses statements that chan ...
- Java并发--安全发布对象
单例模式 懒汉模式:多线程非线程安全,在多线程中,可能会产生多个对象 饿汉模式:线程安全. 类加载的时候初始化,不推荐在构造函数需要做耗时操作的时候使用,因为可能导致类加载缓慢,而且可能初始化后并没有 ...