MongoDB学习笔记(二、MongoDB查询)
目录:
- MongoDB数据类型
- MongoDB新增语法
- MongoDB查询语法
- MongoDB查询选择器
- MongoDB关联查询
MongoDB数据类型:

MongoDB新增语法:
语法:db.collectionName.insert(document)
示例:
1、db.local.insert({name:'thinking in java', price:88.08})
2、或者是先定义变量
var data = {name:'jdr', age:18}
db.local.insert(data)
MongoDB查询语法:
db.collectionName.find(query, projection)
参数说明:
1、query:可选;可使用查询操作符指定查询条件。
2、projection:可选;可指定返回的键,若不指定则返回所有的键(1=显示,0=不展示)
示例:
1、查询所有:db.local.find()
2、查询指定条件:db.local.find({name: 'zd'})
3、如果想要返回的数据易读的话可加上pretty():db.local.find({name: 'zd'}).pretty()
4、指定返回name:db.local.find({},{name:1})
5、指定不返回name:db.local.find({},{name:0})
MongoDB查询选择器:
1、范围选择器、布尔选择器、正则选择器:

2、排序选择器:1=升序,-1=降序
db.local.find().sort({name:1, age:-1})
3、跳过和限制选择器,跳过前面n条数据,限制和mysql中limit效果一致
db.local.find().skip(1).limit(2)
4、过滤重复字段选择器,和mysql中distinct一致
db.local.distinct()
5、 数组选择器
)单元素查询:db.local.find({'favorites.movies':'凹凸曼'})
)多元素查询:db.local.find({'favorites.movies':{'$all':['阿凡达', '泰坦尼克号']}})
)精准查找:db.local.find({'favorites.movies':['凹凸曼', '美队2', '喜羊羊与灰太狼']})
)索引查询(查找数组中第一个钢铁侠的喜欢电影):db.local.find({'favorites.movies.0':'钢铁侠'})
)数组子集:db.local.find({}, {'favorites.movies':{'$slice':[3,3], '_id':1}})
'$slice':[3,3]:跳过前3条数据并取3条数据
6、对象数组选择器
)单元素查询:db.local.find({'citys':{'code':0001, 'addr':'上海'}})
)多元素查询:db.local.find({'comments':{'$elemMatch':{'movies':'倩女幽魂', 'content':'好看!'}}})
demo:https://github.com/mrjdrs/mongodb-demo/tree/master/mongo-selector
MongoDB关联查询:
因mongo单个文档大小不能超过16M,但因特殊的业务场景我们又不得不这样存储,为了解决这一问题mongo提供了DBRef。
DBRef语法:
1、$ref:引用文档所在聚合名称。
2、$id:所在集合的id值。
3、$db:可选;集合所在库的实例名。
示例:
db.collectionName.insert({"name":"zd", "userId":
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"}
})
db.collectionName.insert({"name":"zd", "userId":
[
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"},
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"},
]
})
db.collectionName.findOne({"name":"zd"}).userId.fetch()
db.collectionName.findOne({"name":"zd"}).userId[0].fetch()
MongoDB学习笔记(二、MongoDB查询)的更多相关文章
- Mongodb学习笔记二(Mongodb基本命令)
第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ...
- MongoDB学习笔记二- Mongoose
MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...
- Mongodb学习笔记一(Mongodb环境配置)
Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ...
- MongoDB学习笔记一(MongoDB介绍 + 基本指令 + 查询语句)
什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供可扩 ...
- MongoDB学习笔记二—Shell操作
数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...
- MongoDB学习笔记三:查询
MongoDB中使用find来进行查询.查询就是返回一个集合中文档的子集,子集合的范围从0个文档到整个集合.find的第一个参数决定了要返回哪些文档,其形式也是一个文档,说明要执行的查询细节.空的查询 ...
- MongoDB学习笔记(一) MongoDB介绍及安装(摘)
MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/值存储方式.Mongo使用C++开发.Mongo的官方网 ...
- MongoDb 学习笔记(一) --- MongoDb 数据库介绍、安装、使用
1.数据库和文件的主要区别 . 数据库有数据库表.行和列的概念,让我们存储操作数据更方便 . 数据库提供了非常方便的接口,可以让 nodejs.php java .net 很方便的实现增加修改删除功能 ...
- MongoDB学习笔记~索引提高查询效率
回到目录 索引这个东西大家不会陌生,只要接触到稍微大一点的数据,都会用到这东西,它可以提升查询的速度,相当代价就是占用了更多的存储空间,这也是正常的,符合“能量守恒定理”,哈哈!今天说的是MongoD ...
- MongoDB学习笔记二:创建、更新及删除文档
插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个&q ...
随机推荐
- 【每天一题】LeetCode 0026. 删除排序数组中的重复项
开源地址:https://github.com/jiauzhang/algorithms 题目描述 /* * https://leetcode-cn.com/problems/remove-dupli ...
- 【JS档案揭秘】第三集 深入最底层探秘原型链
关于这部分我看过大量的文章,数不胜数,包括阮一峰的继承三部曲,还有各种慕课的视频教程,网上无数继承方法的对比.也对很多概念存在长期错误的理解.今天做一个正确的总结,用来给原型链和继承这块知识画上句号, ...
- 【转载】C#中decimal保留2位有效小数
在C#的数字运算过程中,有时候针对十进制decimal类型的计算需要保留2位有效小数,针对decimal变量保留2位有效小数有多种方法,可以使用Math.Round方法以及ToString先转换为字符 ...
- Dynamics 365-当OrganizationServiceProxy是Null的时候
不少从事D365研发工作的朋友,可能或多或少都经历过这么一种情况,使用CrmServiceClient对象初始化一个实例,然后发现OrganizationServiceProxy对象是null.不仅如 ...
- C lang: The caracter reverse
Ax_Code #include<stdio.h> int main(void) { int i; char string[7] = {"mrsoft"}; char ...
- 我应该怎么学习SAP?
越来越多的人关注本公众号,在后台留言问我怎么进入SAP行业,应该怎么学习SAP,大部分都是外行想入行SAP的朋友.作为过来人,这些问题我也曾经问过别人,也走过不少弯路.但现在轮到别人问我了,为了让初学 ...
- php5.6 上传图片error代码为6 或者 报错“PHP Warning: File upload error - unable to create a temporary file in Unknown on line 0”的解决办法
问题:再利用webuploader上传图片的时候发现,报错,打印了$_FILES["file"]["error"] 发现是6,找不到临时文件夹: $_FILES ...
- 【bzoj2159】Crash 的文明世界(树形dp+第二类斯特林数)
传送门 题意: 给出一颗\(n\)个结点的树,对于每个结点输出其答案,每个结点的答案为\(ans_x=\sum_{i=1}^ndis(x,i)^k\). 思路: 我们对于每个结点将其答案展开: \[ ...
- canvas应用
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- xamarin调试android部署到模拟器错误记录:Deployment failed Mono.AndroidTools.InstallFailedException: Unexpected install output: Error: Could not access the Package Manager. Is the system running?
问题记录: 1.生成 ok. 2.昨天也是能部署到模拟器的. 但是今天部署的时候就报了这样的一个错误 Deployment failed Mono.AndroidTools.InstallFailed ...