Mongodb 中常用的更新操作
来源:互联网 发布:ugnx是什么软件 编辑:程序博客网 时间:2024/05/20 13:39
上期我们介绍了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的对象和一些更新的操作符(如
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 中常用的更新操作
- MongoDB 的更新操作
- MongoDb的更新操作
- C# 中 MongoDB 更新操作
- MongoDB基础学习二----MongoDB中常用的索引操作
- mongodb的常用 操作
- MongoDB的常用操作
- Mongodb特殊的更新操作
- MongoDB 文档的更新操作
- MongoDB 文档的更新操作
- MongoDB 文档的更新操作
- MongoDB常用的操作命令
- MongoDB 的基本常用操作
- MongoDB常用的操作命令
- 理论---mongoDB的常用操作
- 常用的 MongoDB 操作命令
- mongodb中聚类中常用的操作
- mysql常用操作【更新中】
- java nio理解(2)
- 关于adt中的sdk的环境配置
- 【半年总结】我的2016----把自己当做太阳~~
- Hibernate 所有缓存机制详解(转)
- 关于重写equals();
- Mongodb 中常用的更新操作
- 打包sublime text 3开发环境之Sublime-HTMLPrettify插件打包方法
- java.lang.NoSuchMethodError: org.codehaus.plexus.util.DirectoryScanner.setupMatchPatterns()解决办法
- Node.Js fs模块操作文件(二)
- leetcode_c++:Divide and Conquer:. Search a 2D Matrix II(240)
- View树的绘图流程
- MongoDB学习笔记-数据导入Excel文件
- LeetCode OJ(6.ZigZag Conversion)
- mybatis---创建序列