一、引言
上一篇文章我们已经详细介绍了MongoDB数据库的有关查询的内容,但是这只是所有查询命令的冰山一角。所有查询命令都写完也没有必要,我只是写了一些常用的命令,对MongoDB的操作有一个基本的认识,如果大家想继续深入,可以根据自己的需要深入学习其他的命令。今天要讲一些和更新、修改有关系的语句、命令或者方法,当然不可能是所有的命令了,也只是一些常用的命令。我提供给大家一个基础,大家可以继续深入,我也会继续深入学习的。废话不多说,马上开始我们今天的写作吧。
二、MongoDB有关修改的详解
我比较直接,还是直接来内容吧,有关修改的每个方法都有示例代码,应该不是很难,希望能起到抛砖引玉的作用吧。
1、update() 方法
1.1、update() 方法用于更新已存在的文档。语法格式如下:
db.collectionName.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
参数说明:
query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如$set,$inc...)等,也可以理解为sql update查询内set后面的
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入新的文档,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。
1.2、示例代码
> db.students.find({"name":FangShiYu"}) { _id" : ObjectId(5ab9de223afa6504457050e2")," : ",1)">age22,1)">sex1,1)">schoolZheJiangDaXueaddressGuangDongGuangZhou } //修改【name】是【FangShiYu】的【age】字段的值为【25】 > db.students.update({"},{$set":{25}}) WriteResult({ nMatchednUpserted0,1)">nModified1 }) > db.students.find({}) { 25,1)">" }