MongoDB(二)创建更新删除文档

插入并保存文档操作

用insert向目标集合插入文档,如果没有_id键则会自动添加。最后自动保存。

>db.foo.insert({"bar":"baz"})

如果要批量插入怎么办呢,看下面代码:

>db.foo.insert([{"_id":0},{"_id":1},"{"_id":2}])

以前有一个batchInsert函数,现在已经没有了。注意在批量插入的过程中如果有一个文档插入失败,则这个文档和他之后的文档都会插入失败。如果想要忽略错误并且继续执行就这么写:

db.foo.insert([{"_id":3},{"_id":4},{"_id":3},{"_id":5}],continueOnError=true)

在插入数据的时候,mongoDB只会进行简单的校验:检查文档的基本结构,如果没有_id就自动增加一个。检查大小,所有的文档都得<16MB(设计者认为设定的,以后也可能变)。如果想要查看一个文档的BSON大小,那么可以这么做:

Object.bsonsize({"x":1})

这样就可以获得文档的BSON大小。不知道什么是bson请看这个Bson是什么

由于MongoDB只进行最基本的检查,所以插入非法数据非常容易。那么我们在这个过程中应该只允许信任的源链接服务器。

删除文档

删除全部文档命令:

db.foo.remove({})

删除满足特定条件的文档:

db.foo.remove({title:"blog"})

这个会删除满足title=blog的文档,我们也可以只删除一个满足条件的文档:

db.foo.remove({title:"blog"},1)

这个命令会删除第一个满足条件的文档。

在删除全部文档的时候,我们用drop()直接删除集合会更快,但是drop只能全部删除,并不能指定条件删除!

更新文档

用update来更新文档,update有两个参数,一个是查询文档,用于定位需要更新的目标文档;另外一个是修改器,用于说明要对找到的文档进行哪些修改.更新操作是不可分割的,若两个更新操作同时发生,那么先到达服务器的先执行,再执行另外一个。

1.替换文档

假设我们之前的文档是{“_id":0,"name":"faner","friends":88,"enemies":2},现在我们想将friends和enemises两个字段移到子文档relationship中,最简单的方法就是用一个新文档来替换我们之前的文档那么我们应该这么做

var faner = db.tester.findOne({name:"faner"});
faner.relationship = {"friends":faner.friends,"enemies":faner.enemies};
delete faner.friends;
delete faner.enemies;
db.tester.update({name:"faner"},faner};

这样我们就完成了我们的替换.但是注意如果查询条件匹配到了多个文档,更新时因为第二个参数的原因会导致所有的_id相同,数据库就会跑出错误,任何文档都不会更新。所以在更新时最好通过唯一键值来指定唯一文档!
比如说_id,并且用_id查询比其他字段快,这是因为索引的关系,我们暂且不谈。

2.使用修改器

如果文档只有一部分要更新,那么我们可以使用原子性(不懂的自己百度吧。毕竟这可是一项基本技能~)的更新修改器,指定对文档的某些字段进行更新。

 db.tester.update({name:"faner"},{$set:{x:22}})

这句话的意思是我们找到name=faner的文档并把他的x变成22,这里使用了我们的set修改器.$set修改器用来修改一个字段的值,如果这个字段不存在则会创建它,除了修改值之外我们还能改变键的类型,如下:

db.tester.update({name:"faner"},{$set:{x:[1,2,3,4]}})

这样我们把我们的x变成了一个数组,相应的我们还能变成内嵌文档以及其他类型,具体的请自己试试。

如果我们想删除一个键,我们也可以用$unset来完成我们的想法:

db.tester.update({name:"faner"},{$unset:{x:1}})

注意这个字段x后面的值无意义,什么都可以,我是习惯写1而已,每个人根据自己的习惯写自己的代码。

除了我们的$set和$unset外,我们还有$inc修改器(自增),$push修改器(向已有的数组末尾加入一个元素)等等.

下面我们通过代码来看看各个修改器的作用:

 db.tester.update({name:"faner"},{$inc:{x:1}})
//inc修改器用来自增
//$push修改器用来在数组后面增加一个元素
db.tester.update({name:"faner"},{$push:{x:5}})
//push和each结合添加一组元素
 db.tester.update({name:"faner"},{$push:{x:{$each:[6,7,8]}}})//如果希望数组的个数是固定的,则用slice  这里假设数组长度固定为10个,这里保留的是最后加进来的10个元素db.tester.update({name:"faner"},{$push:{x:{$each:[6,7,8],$slice:-10}}})//如果我想按照某一字段的大小来保留10个值呢,这里就要用到我们的$sort//按照字段x的递减顺序排序保留10 个db.tester.update({name:"faner"},{$push:{x:{$each:[6,7,8],$slice:-10,$sort:{"x":-1}}}})//如果我们不想数数组中的数字有重复的就用$addToSet addToSet也可以和each连用db.tester.update({name:"faner"},{$addToSet:{x:2}})//删除一个数组中的元素就用$pop 和$pull(删除多个元素) db.tester.update({name:"faner"},{$pop:{x:1}})  //从尾部删除一个元素 db.tester.update({name:"faner"},{$pop:{x:-1}}) //从头部删除一个元素//对于数组的一部分进行操作用$定位操作符

upsert是一种特殊的更新,要是没有找到符合更新条件的文档,则他会自己创建一个新的文档,找到了就正常更新文档。使用upsert的方式就是在update的第三个参数写成true即可,默认为false。

还有$setOnInsert,它只会在第一次修改时设置,以后的更新他就不会改变。sava函数能进行快速修改,如db.tester.save(x)  sava是一个shell函数,如果文档中含有_id键则会调用upsert,否则会调用insert。

更新多个文档

默认情况下,更新只对满足于匹配条件的第一个文档进行更新。如果要更新所有匹配文档,则设置update的第四个参数为true即可.要想知道更新了多少文档科用命令:db.runCommand({getLastError:1})(返回最后一次操作的相关信息,n即是被更新文档的数量)

返回被更新的文档

用findAndModify命令来得到被更新的文档,findAndModify定义和作用官方文档

大家自己看官方上的说明,我就不啰嗦了。

时间: 2024-10-12 07:53:54

MongoDB(二)创建更新删除文档的相关文章

MongoDB创建\更新\删除文档操作

?? 一.插入\创建文档 --当插入一个不存在的文档时,会自动创建一个文档 [[email protected] ~]# mongo MongoDB shell version: 2.4.14 connecting to: test > show collections > db.cols.insert({bar:"baz"}) > db.cols.find() { "_id" :ObjectId("56aac1df4e61b6d9f84

大数据技术之_20_Elasticsearch学习_01_概述 + 快速入门 + Java API 操作 + 创建、删除索引 + 新建、搜索、更新删除文档 + 条件查询 + 映射操作

一 概述1.1 什么是搜索?1.2 如果用数据库做搜索会怎么样?1.3 什么是全文检索和 Lucene?1.4 什么是 Elasticsearch?1.5 Elasticsearch 的适用场景1.6 Elasticsearch 的特点1.7 Elasticsearch 的核心概念1.7.1 近实时1.7.2 Cluster(集群)1.7.3 Node(节点)1.7.4 Index(索引 --> 数据库)1.7.5 Type(类型 --> 表)1.7.6 Document(文档 -->

REST API (更新删除文档)

Elasticsearch的更新文档API准许通过脚本操作来更新文档.更新操作从索引中获取文档,执行脚本,然后获得返回结果.它使用版本号来控制文档获取或者重建索引. 我们新建一个文档: 请求:PUT http://localhost:9200/test/type1/1?pretty 参数: { "counter" : 1, "tags" : ["red"] } 脚本开启功能 在最新版本的Elasticsearch中,基于安全考虑(如果用不到,请保

MongoDB学习笔记二:创建、更新及删除文档

插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个"_id"键(要是原来没有的话),然后将其保存到MongoDB中.批量插入 如果要插入多个文档,使用批量插入会快一些.批量插入传递一个由文档构成的数组给数据库.如果只是导入数据(例如,从数据feed或者MySQL中导入),可以使用命令行工具,如mongoimport,而不是使用批量插入. 删除

MongoDB创建、更新及删除文档

1.1插入并保存文档 插入是向MongoDB中添加数据的基本方法.对目标机使用insert方法,插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个"_id"键(要是原来没有的话),然后将其保存到MongoDB中. 1.1.1 批量插入 如果要插入多个文档,使用批量插入会快一些.批量插入能传递一个由文档构成的数组给数据库.只有插入多个文档到一个集合的时候,这种方式才会有用,而不能批量插入

MongoDB学习笔记-创建、更新、删除文档

创建 MongoDB中使用insert方法来向集合插入文档,然后保存到MongoDB中. db.foo.insert({“hehe”:”呵呵”}) 如果想批量插入的话可以使用下面这种形式:db.foo.insert([{“hehe”:”呵呵”},{“haha”:”哈哈”}]) 插入校验 插入数据时MongoDB只对数据进行最基本的检查-检查文档的基本结构.如果没有“_id”字段,就会自动增加一个,所有文档都必须小于16MB(这个值是MongoDB设计者人为定义的,未来可能会增加).这样的限制主要

创建、更新、删除文档。 --- Mongodb权威指南阅读。

插入文档: db.foo.insert({ "key" : "value"}); 使用insert插入一个数据,文档中如果没有_id 会自动给文档增加_id. batchInsert(Array)  批量插入,接受一个文档数组做参数. 使用批量插入最大长度48M,如果过程中一个失败,失败之前会插入成功,之后全都失败. 可以设置continueOnError 选项设置忽略错误并且继续插入. 插入校验: 所有文档必须都小于16M. 删除文档: db.foo.remove

mongoDB更新和删除文档(document)

整理来自 https://www.shiyanlou.com/courses/running/57 启动 $ sudo service mongodb start 进入MongoDB命令行操作界面,在命令行中敲exit可以退出 $ mongo 实验中的布尔类型的ture用1代替,false用0代替 创建数据库 范例:进入mongoDB命令行操作界面之后,进行如下操作: > use Chenshi switched to db Chenshi 您可以使用db命令查看您当前选择的数据库 > db

03.创建、更新和删除文档。

插入: >db.collectionName.insert({"bar":"baz")} 批量插入:如果要向集合插入多个文档,使用批量插入会快一些. batchInsert函数实现批量插入,它接受一个文档数组作为参数. >db.collectionName.batchInsert([ {"_id:0}, {"_id":1}, {"_id":2} ]) >db.collectionName.find(