MongoDB(五):MongoDB操作文档
本篇文章中将讲解如何使用MongoDB操作文档。
文档的数据结构和JSON基本一致,所有存储在集合中的数据都是BSON格式。BSON是一种类似json格式的一种二进制形式的存储格式,简称Binary JSON。
一、插入文档
MongoDB使用insert()或save()方法向集合中插入文档,语法如下:
db.COLLECTION_NAME.insert(document)
例如:以下文档可以存储在MongoDB的test数据库的MongoDBTest集合中:
{"title" : "MongoDB", "description" : "mongoDB是一个NoSql数据库", "tags" : "NoSql" }
1、使用insert()方法插入文档
在上面的例子中,MongoDBTest是我们的集合名,如果该集合不在该数据库中,MongoDB会自动创建该集合并插入文档。doc是定义的变量,可以以变量的形式插入集合。
查看已经插入的文档:
> db.MongoDBTest.insert(doc)
WriteResult({ "nInserted" : 1 })
> db.MongoDBTest.find()
{ "_id" : ObjectId("5a6f13e72d0b37669c5d2a78"), "title" : "MongoDB", "description" : "mongoDB是一个NoSql数据库", "tags" : "NoSql" }
>
2、使用save()方法插入文档
插入文档也可以使用save()方法。如果不知道_id字段save()方法类似于insert()方法。如果指定_id字段,则会更新该_id的数据。
下面的例子表示使用save()命令更新数据:
二、查询文档
MongoDB查询文档使用find()方法。
find()方法以非结构化的方式来显示所有文档。
1、语法
MongoDB查询数据的语法格式如下:
db.collection.find(query,projection)
参数说明:
query:可选参数,使用查询操作符指定查询条件。
projection:可选参数,使用投影操作符指定返回的键。如果查询时要返回文档中所有键值,只需省略该参数即可(默认省略)。
如果你需要格式化读取的数据,可以使用pretty()方法,语法格式如下:
db.collection.find().pretty()
pretty()方法以格式化的方式来显示所有文档。
2、实例
例如:查询Student集合中的所有文档。
除了find()方法之外,还有一个findOne()方法,它只返回一个文档。
MongoDB与RDBMS where语句比较
如果你熟悉常规的SQL数据,通过下表可以更好的理解MongoDB的条件语句查询:
操作 | 格式 | 范例 | RDBMS中的类似语句 |
等于 | {<key>:<value>} | db.Student.find({"name":"张三"}).pretty() | where name='张三' |
小于 | {<key>:{$lt:<value>}} | db.Student.find({"score":{$lt:"80"}}).pretty() | where score<80 |
小于或等于 | {<key>:{$lte:<value>}} | db.Student.find({"score":{$lte:"80"}}).pretty() | where score<=80 |
大于 | {<key>:{$gt:<value>}} | db.Student.find({"score":{$gt:"80"}}).pretty() | where score>80 |
大于或等于 | {<key>:{$gte:<value>}} | db.Student.find({"score":{$gte:"80"}}).pretty() | where score>=80 |
不等于 | {<key>:{$ne:<value>}} | db.Student.find({"score":{$ne:"80"}}).pretty() | where score!=80 |
(1)查询name是张三的学生
db.Student.find({"name":"张三"}).pretty()
查询结果如下图所示:
(2)查询成绩小于80的学生
db.Student.find({"score":{$lt:"80"}}).pretty()
查询结果如下图所示:
(3)查询成绩小于等于80的学生
db.Student.find({"score":{$lte:"80"}}).pretty()
查询结果如下图所示:
(4)查询成绩大于80分的学生
db.Student.find({"score":{$gt:"80"}}).pretty()
(5)查询成绩大于等于80分的学生
db.Student.find({"score":{$gte:"80"}}).pretty()
查询结果如下图所示:
(6)查询成绩不等于80分的学生
db.Student.find({"score":{$ne:"80"}}).pretty()
查询结果如下图所示:
3、MongoDB AND条件查询
MongoDB的find()方法可以传入多个键(key),每个键(key)以逗号分隔开,等价于常规SQL的AND条件。
语法格式如下:
db.collection.find({key1:value1,key2:value2}).pretty()
例如:查询姓名为张三并且课程是C#程序设计的学生信息。
db.Student.find({"name":"张三","subject":"C#程序设计"}).pretty()
查询结果如下图所示:
以上实例中类似于RDBMS中的where语句:WHERE name='张三' AND subject='C#程序设计'。
4、MongoDB OR 条件查询
MongoDB的OR条件语句使用了关键字$or,语法格式如下:
>db.collection.find(
{
$or:[
{key1:value1},{key2:value2}
]
}
)
例如:查询姓名是李四或者成绩等于80的学生
db.Student.find({$or:[{"name":"李四"},{"score":"80"}]}).pretty()
查询结果如下图所示:
三、更新文档
MongoDB使用update()和save()方法来更新集合中的文档。接下来让我们详细来看下两个方法的应用及其区别。
1、update()方法
update()方法用于更新已经存在的文档。语法格式如下:
db.collection.update(
<query>,
<update>,
{
upsert:<boolean>,
multi:<boolean>,
writeConcern:<document>
}
)
参数说明:
query:update的查询条件,类似sql update查询内where后面的条件。
update:update的对象和一些更新的操作符(如$set,Sinc......)等,也可以理解为sql update查询内set后面的。
upsert:可选参数,这个参数的意思是:如果不存在update的记录,是否插入新的文档。如果为true则插入,默认是false不插入。
multi:可选参数,MongoDB默认是false,只更新找到的第一条记录。如果这个参数为true,就把按条件查询出来的多条记录全部更新。
writeConcern:可选参数,抛出异常的级别。
writeConcern的几种抛出异常的级别参数
writeConcern.NONE:没有异常抛出。
writeConcern.NORMAL:仅抛出网络错误异常,没有服务器错误异常抛出。
writeConcern.SAFE:抛出网络错误异常、服务器错误异常;并等待服务器完成写操作。
writeConcern.MAJORITY:抛出网络错误异常、服务器错误异常;并等待一个主服务器完成写操作。
writeConcern.FSYNC_SAFE:抛出网络错误异常、服务器错误异常;写操作等待服务器将数据刷新到磁盘。
writeConcern.JOURNAL_SAFE:抛出网络错误异常、服务器错误异常;写操作等待服务器提交到磁盘的日志文件。
writeConcern.REPLICAS_SAFE:抛出网络错误异常、服务器错误异常;等待至少2台服务器完成写操作。
例如:使用update()方法更新标题(title)
上面的语句只会更新第一条查询到的文档,如果你要更新多条相同的文档,则需要设置multi参数为true。
如果要更新的数据不存在,upsert参数设置为true则会插入数据。
2、save()方法
save()方法通过传入的文档来替换已有文档,语法格式如下:
db.collection.save(
<document>,
{
writeConcern:<document>
}
)
参数说明:
document:要更新的文档数据。
writeConcern:可选参数,抛出异常的级别。
例如:更新_id=5a702a7f2c6ed8f4d3491831的文档。
四、删除文档
MongoDB使用remove()方法来移除集合中的数据。
注意:在执行remove()方法前先执行find()命令来判断执行的条件是否正确,这是一个比较好的习惯。
remove()方法的基本语法格式如下:
db.collection.remove(
<query>,
<justOne>
)
如果MongoDB是2.6版本以后的,语法格式如下:
db.collection.remove(
<query>,
{
justOne:<boolean>,
writeConcern:<document>
}
)
参数说明:
query:可选参数,删除文档的条件。
justOne:可选参数,如果设为true或1,则只删除一个文档。
writeConcern:可选参数,抛出异常的级别。
实例
1、删除title为MongoDB教程的文档,只删除一个:
2、删除所有数据
如果想删除所有数据,可以使用下面的例子
MongoDB(五):MongoDB操作文档的更多相关文章
- Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)
Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...
- MongoDB第四天(操作文档,添加,更新,查询以及对于日期的相关操作)
添加文档: 添加单个文档,多个文档 package com.bjsxt.mongodbdemo; import com.mongodb.client.MongoCollection; import o ...
- MongoDB(五):更新文档、删除文档
1. 更新文档 MongoDB的uptade()和save()方法用于将集合中的文档更新.update()方法更新现有文档中的值,而save()方法是传递文档数据替换现有文档.从3.2版本开始,Mon ...
- MongoDB (五) MongoDB 数据库操作
一.MongoDB创建数据库: use 命令 MongoDB use DATABASE_NAME 用于创建数据库.该命令将创建一个新的数据库,如果它不存在,否则将返回现有的数据库. 语法: use D ...
- ElasticSearch 基础入门 and 操作索引 and 操作文档
基本概念 索引: 类似于MySQL的表.索引的结构为全文搜索作准备,不存储原始的数据. 索引可以做分布式.每一个索引有一个或者多个分片 shard.每一个分片可以有多个副本 replica. 文档: ...
- pageoffice razor pageofficelink方式调用js实现操作文档
用官方的开发者帮助文档即可,在后台实例化时一定要将pageofficecontrol控件的id属性定义,然后在前台通过定义的id属性来调用相应的方法
- SEO配置信息操作文档
一.title(网站标题) title,就是浏览器上显示的那些内容,不仅用户能看到,也能被搜索引擎检索到(搜索引擎在抓取网页时,最先读取的就是网页标题,所以title是否正确设置极其重要.)title ...
- 从域名到网站,快速创建全新社区站点 - phpwind一键部署操作文档
关于phpwind一键部署服务,请查阅PW官网:http://www.phpwind.com/setup.html 选择一键部署镜像版本,立即开始使用: PW建站系统(Centos 64位) ———— ...
- IDEA使用操作文档
IDEA中怎么设置黑色或白色背景? http://jingyan.baidu.com/article/4e5b3e19330df191911e246b.html 一. IntelliJ IDEA 的 ...
随机推荐
- 房产地图google map的初步应用点滴.1)(转)
房产地图google map的初步应用点滴.1)房产地图google map的初步应用点滴.2)房产地图google map的初步应用点滴.3) 房产地图google map的初步应用点滴.4) 以前 ...
- SQL Server里面导出SQL脚本(表数据的insert语句)
转载自:http://hi.baidu.com/pigarmy/blog/item/109894c445eab0a28326ac5a.html 最近需要导出一个表的数据并生成insert语句,发现SQ ...
- R.string获取的是数字或者R.integer数字不对的问题
String msg = R.string.menu_title; 获取menu_title的String值,但发现这样写报错,原因R.string.menu_title是int类型的,可是通过以下方 ...
- RHEL7 -- RPM包命名规则
rpm软件包文件采用软件包名称组合name-version-release.architecture的方式进行命名 以下面的rpm包为例: kernel-devel--.el7.x86_64 ·na ...
- SSAS多维数据集以及维度的建立
首先打开vs建立一个Analysis Services项目,然后点击数据源文件右键[新建数据源],根据数据源向导建立自己的数据源,如图1: 点击[确定],选择刚才的数据连接,点击[下一步]进入模拟信息 ...
- shutdown 与 close 函数 的区别
假设server和client 已经建立了连接,server调用了close, 发送FIN 段给client(其实不一定会发送FIN段,后面再说),此时server不能再通过socket发送和接收数据 ...
- 利用ARP和ICMP协议解释ping命令
一.MTU 以太网和IEEE 802.3对数据帧的长度都有限制,其最大值分别是1500和1492字节,将这个限制称作最大传输单元(MTU,Maximum Transmission Unit).如果IP ...
- http连接优化
http连接的性能优化 并行连接(能够同一时候和多台server建立HTTP连接) 持久连接 管道化连接 复用的连接 并行连接 长处: 并行连接能够在带宽资源充足的情况下同一时候建立多个HTTP连接, ...
- java与java学习路线
JAVA学习路线图 Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承.指针等概念,因此Java语言具有功能强大和简单易用两个特征.Java语言作为静态面 ...
- php序列化与反序列化时字符集不一致问题的解决办法
今天的用PHP的时候无意的出现了用unserialize()函数转换老是返回false,我确认我的字符串是没错的,测试了很多次还是一样,没办法,启用了error_reporting(E_ALL)启用错 ...