MongoDB数据修改总结

MongoDB数据修改总结
2013-10-26 10:08:30      我来讲两句     来源:huhui的专栏   
收藏  我要投稿
MongoDB数据修改总结
 
1.前言
最近在学习MongoDB,数据修改这一部分的内容较多,命令比较繁琐,因此将一些经常使用的修改命令总结在这篇博客中,方便从此学习的查阅。
2.命令总结
1). insert()
db.collection.insert(x)  x就是要更新的对象,只能是单条记录,如:
[plain]
db.collection.insert({_id:1,name:"test",count:1}) 
当须要批量插入的时候,能够在shell中使用for循环,如:
[plain]
for(var i=0;i<16;i++){  
     db.mytest.insert({_id:i,name:"test"+i,count:i})  
此时若是用find()命令查询插入的数据,结果是这样的:
[plain]
> db.mytest.find() 
{ "_id" : 0, "name" : "test0", "count" : 0 }
{ "_id" : 1, "name" : "test1", "count" : 1 }
{ "_id" : 2, "name" : "test2", "count" : 2 }
{ "_id" : 3, "name" : "test3", "count" : 3 }
{ "_id" : 4, "name" : "test4", "count" : 4 }
{ "_id" : 5, "name" : "test5", "count" : 5 }
{ "_id" : 6, "name" : "test6", "count" : 6 }
{ "_id" : 7, "name" : "test7", "count" : 7 }
{ "_id" : 8, "name" : "test8", "count" : 8 }
{ "_id" : 9, "name" : "test9", "count" : 9 }
{ "_id" : 10, "name" : "test10", "count" : 10 }
{ "_id" : 11, "name" : "test11", "count" : 11 }
{ "_id" : 12, "name" : "test12", "count" : 12 }
{ "_id" : 13, "name" : "test13", "count" : 13 }
{ "_id" : 14, "name" : "test14", "count" : 14 }
{ "_id" : 15, "name" : "test15", "count" : 15 }
 
2). update()
db.collection.update( criteria, objNew, upsert, multi )    四个参数的说明以下:
criteria: update的查询条件,相似sql update查询内where后面的
objNew: update的对象和一些更新的操做符(如$,$inc...)等,也能够理解为sql update查询内set后面的
upsert: 这个参数的意思是,若是不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi: mongodb默认是false,只更新找到的第一条记录,若是这个参数为true,就把按条件查出来多条记录所有更新。
几个查询例子以下:
db.mytest.update({count:{$gt:1}},{$set:{name:"ok"}})                                  只更新第一条记录
db.mytest.update({count:{$gt:3}},{$set:{name:"ok"}},false,true)                  大于3的所有更新了
db.mytest.update({count:{$gt:4}},{$set:{name:"ok123"}},true,false)            只更新了一条
db.mytest.update({count:{$gt:6}},{$set:{name:"ok123"}},true,true)              大于6的所有更新了
 
3). save()
db.collection.save(x) x是要插入的对象,效果与上面的insert命令同样。save与insert的区别是这样的:
在进行插入数据的操做中,当遇到_id相同的状况下,save完成保存操做,insert则会保存;即_id相同状况下,save至关于更新操做。
 
下面是一些MongoDB的更新操做符
 
4). $inc
用法:{$inc:{field:value}}   意思是对一个数字字段field增长value:
[plain]
> db.mytest.find({_id:1})      
{ "_id" : 1, "name" : "test1", "count" : 1 } 
> db.mytest.update({_id:1},{$inc:{count:1}}) 
> db.mytest.find({_id:1}) 
{ "_id" : 1, "name" : "test1", "count" : 2 }  //count字段加1 
 
value的值也能够为负,就至关于减一个值:
[plain]
> db.mytest.update({_id:1},{$inc:{count:-2}}) 
> db.mytest.find({_id:1}) 
{ "_id" : 1, "name" : "test1", "count" : 0 }  //值从2减到0 
 
5). $set命令
用法:{$set:{field:value}}
至关于在关系型 数据库中sql的set field=value,所有数据类型都支持$set操做
[plain]
> db.mytest.update({_id:1},{$set:{count:111}}) 
> db.mytest.find({_id:1}) 
{ "_id" : 1, "name" : "test1", "count" : 111 }   //修改数值型 
> db.mytest.update({_id:1},{$set:{name:"MongoDB"}}) 
> db.mytest.find({_id:1}) 
{ "_id" : 1, "count" : 111, "name" : "MongoDB" }   //修改字符型 
 
6). $unset
用法:{$unset:{field:1}}
[plain]
> db.mytest.find({_id:1}) 
{ "_id" : 1, "count" : 111, "name" : "MongoDB" } 
> db.mytest.update({_id:1},{$unset:{name:1}}) 
> db.mytest.find({_id:1}) 
{ "_id" : 1, "count" : 111 }  //删除了字段name 
 
7). $push
用法:{$push:{field:value}}
把value追加到field中取,field必定是数据类型才行,若是field不存在,会新增一个数组类型加进去:
[plain]
> db.mytest.update({_id:15},{$set:{array:["aaa","bbb"]}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb" ], "count" : 15, "name" : "ok123" } 
使用push追加数据:
[plain]
> db.mytest.update({_id:15},{$push:{array:"ccc"}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb",  "ccc" ], "count" : 15, "name" : "ok123" } 
push一次只能追加一个值,若是须要追加多个值,则须要使用$pushAll:
[plain]
> db.mytest.update({_id:15},{$pushAll:{array:["ddd","eee","fff"]}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb",  "ccc",  "ddd",  "eee",  "fff" ], "count" : 15, "name" : "ok123" } 
 
8). $addToSet
用法:{$addToSet:{field:value}}
增长一个值到数组内,并且只有当这个值不在数组内才增长:
[plain]
> db.mytest.update({_id:15},{$addToSet:{array:"123"}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb",  "123" ], "array2" : [  "mmm",  "nnn"], "count" : 15, "name" : "ok123" } 
> db.mytest.update({_id:15},{$addToSet:{array:"aaa"}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb",  "123" ], "array2" : [  "mmm",  "nnn"], "count" : 15, "name" : "ok123" } 
 
9). $pop
删除数组内的一个值,删除最后一个值:{$pop:{field:1}} ,删除第一个值:{$pop:{field:-1}}
[plain]
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb",  "123" ], "array2" : [  "mmm",  "nnn"], "count" : 15, "name" : "ok123" } 
> db.mytest.update({_id:15},{$pop:{array:1}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb" ], "array2" : [  "mmm",  "nnn" ], "count" : 15, "name" : "ok123" } 
 
10). $pull
用法:$pull:{field:value}   从数组中删除一个等于value的值:
[plain]
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "aaa",  "bbb" ], "array2" : [  "mmm",  "nnn" ], "coun 
t" : 15, "name" : "ok123" } 
> db.mytest.update({_id:15},{$pull:{array:"aaa"}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "bbb" ], "array2" : [  "mmm",  "nnn" ], "count" : 15, 
"name" : "ok123" } 
 
11). $pullAll
用法同$pull,能够一次删除数组内的多个值:
[plain]
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "bbb" ], "array2" : [  "mmm",  "nnn" ], "count" : 15,"name" : "ok123" } 
> db.mytest.update({_id:15},{$pullAll:{array2:["mmm","nnn"]}}) 
> db.mytest.find({_id:15}) 
{ "_id" : 15, "array" : [  "bbb" ], "array2" : [ ], "count" : 15, "name" : "ok123" } 
 
12). $
能够理解为数组定位器,看一个官方文档的例子:
[plain]
> t.find() 
{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 3 }, { "by" : "jane", "votes" : 7 } ] } 
> t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}) 
> t.find() 
{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 4 }, { "by" : "jane", "votes" : 7 } ] } 
须要注意的是,$只会找到第一条数组项,后面的就无论了:
[plain]
> db.mytest.find({_id:16}) 
{ "_id" : 16, "x" : [  1,  2,  3,  1 ] } 
> db.mytest.update({x:1},{$inc:{"x.$":1}}) 
> db.mytest.find({_id:16}) 
{ "_id" : 16, "x" : [  2,  2,  3,  1 ] } 
 
还有一点须要注意,当$配合$unset使用的时候,会留下一个null的数组项,这个问题可使用{$pull:{x:null}}解决:
[plain]
> db.mytest.find({_id:16}) 
{ "_id" : 16, "x" : [  2,  2,  3,  1 ] } 
> db.mytest.update({x:3},{$unset:{"x.$":1}}) 
> db.mytest.find({_id:16}) 
{ "_id" : 16, "x" : [  2,  2,  null,  1 ] } 
> db.mytest.update({_id:16},{$pull:{x:null}}) 
> db.mytest.find({_id:16}) 
{ "_id" : 16, "x" : [  2,  2,  1 ] } 
相关文章
相关标签/搜索