Mongodb 中常用的更新操作

原创 2016年08月28日 15:33:20

上期我们介绍了mongodb 中常用的查询操作,这期说说Mongodb 中常用的更新操作。在Mongodb中更新的命令只有两条。1.update() 2.save()
1. update() 语法规则 :db.collection.update( A, B, C, D ) 。A ,B,C,D四个参数的解释
A 表示update的查询条件,类似sql update查询内where后面的。
B 表示 update的对象和一些更新的操作符(如inc…)等,也可以理解为sql update查询内set后面的
C 这个参数的意思是,如果不存在update的记录,是否插入B,true为插入,默认是false,不插入。
D mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
例子:
db.test0.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一条记录
db.test0.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
db.test0.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加进去了第一条
db.test0.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加进去了
db.test0.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
db.test0.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一条

2.save()
db.collection.save( x ) x就是要更新的对象,只能是单条记录。如果在collection内已经存在一个和x对象相同的”_id”的记录。mongodb就会把x对象替换collection内已经存在的记录,否则将会插入x对象,如果x内没有_id,系统会自动生成一个再插入。相当于上面update语句的C=true,D=false的情况。例子:db.test0.save({count:40,test1:”OK”}); #_id系统会生成
db.test0.save({_id:40,count:40,test1:”OK”}); #如果test0内有_id等于40的,会替换,否则插入。
3. Mongodb 更新中常用的操作符
1.$inc 用法{ $inc : { field : value } }意思对一个数字字段field增加value。

> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 16, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $inc : { "count" : 1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 17, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

2.$set 用法:{ $set : { field : value } }意思就是相当于sql的set field = value,全部数据类型都支持$set。

> db.test0.update( { "_id" : 15 } , { $set : { "test1" : "testv1","test2" : "testv2","test3" : "testv3","test4" : "testv4" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "testv1", "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

3.$unset 用法:{ $unset : { field : 1} } 意思就是删除字段

意思就是删除test0 这个表中的test1:1 这个字段
> db.test0.update( { "_id" : 15 } , { $unset : { "test1":1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

4.$push 用法{ $push : { field : value } }意思就是把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。一次只能追加一个值

就是往test0 这个表的test1 字段数组中添加ccc 这个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb" ], "test4" : "testv4", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $push : { "test1": "ccc" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test4" : "testv4", "test5" : "OK" }

5.$pushAll 用法 { $pushAll : { field : value_array } } 和$push 的用法一样,区别在于$push一次只能追加一个值,$pushAll可以追加多个值

就是往test1 这个字段中同时追加 fff .ggg 这个两个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $pushAll : { "test1": ["fff","ggg"] } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ], "fff", "ggg" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

6.$addToSet 用法{ $addToSet : { field : value } } 意思就是增加一个值到数组内,而且只有当这个值不在数组内才增加

> db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["aaa","bbb","ccc",["ddd","eee"],"fff","ggg",["111","222"],"444","555"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK"


 }

7.$pop删除数组 用法删除最后一个值:{ $pop : { field : 1 } }删除第一个值:{ $pop : { field : -1 } } 意思就是删除数组内某一个值,只能删除一个值,也就是说只能用1或-1

   > db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["bbb","ccc",["ddd","eee"],"fff","ggg",["111","222"],"444"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" 


}
> db.test0.update( { "_id" : 15 } , { $pop : { "test1": -1 } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, 


  "test1" : ["ccc",["ddd","eee"],"fff","ggg",["111","222"],"444"], 


  "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK"

 } 

8.$pull 用法:$pull : { field : value } } 意思就是 从数组field内删除一个等于value值

意思就是删除test0 这个表中test1 数组中的等于ggg 这个值
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
"test5" : "OK" }

> db.test0.update( { "_id" : 15 } , { $pull : { "test1": "ggg" } } );
> db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
: "OK" }

9.$pullAll 用法{ $pullAll : { field : value_array } } 和$pull差不多,就是可以一次删除多个值
更多关于mongodb 操作数据的方法和参数可以参考mongodb 的官方文档

版权声明:本文为博主原创文章,未经博主允许不得转载。

MongoDB常用操作命令大全

  • 2016年03月01日 16:18
  • 60KB
  • 下载

MongoDB Shell 常用操作命令

MonoDB   shell命令操作语法和JavaScript很类似,其实控制台底层的查询语句都是用JavaScript脚本完成操作的。 Ø 数据库  1、Help查看命令提示 he...

MongoDB常用操作命令大全

如果你想创建一个“myTest”的数据库,先运行use myTest命令,之后就做一些操作(如:db.createCollection('user')),这样就可以创 建一个名叫“myTest”的数据...

mongodb 3.2 实战(二)安装配置及常用操作

一、安装配置 wget命令直接下载安装包wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-1.8.5.tgz 配置 一般将软件放...

MongoDB的常用操作(二)

#以服务方式启动mongodb,要求验证 /elain/apps/mongodb/bin/mongod --fork --port 27001 --auth --dbpath/elain/d...

mongodb 常用操作命令大全1

1.查找并且倒排序,限制显示30条 db.getCollection('cars').find({'title':/appy/,'parentCard':0},{'title':1}).sort({...

MongoDB常用操作命令大全

成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作。输入help可以看到基本操作命令,只是MongoDB没有创建数据库的命令,但有类似的命令   如:如果你想创建...

MongoDB学习笔记(一)环境搭建与常用操作

一、MongoDB是什么   MongoDB是一个基于分布式文件存储的数据库,旨在为WEB应用提供可扩展的高性能数据存储解决方案。   它介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能...

MongoDB常用操作(二)

下载MongoDB  进到官网下载你需要的MondoDB版本,这里我们现在mongodb-win32-x86_64-2008plus-ssl-3.2.13.zip这个版本。安装MongoDB把下载后的...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Mongodb 中常用的更新操作
举报原因:
原因补充:

(最多只允许输入30个字)