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数组操作$(update)、$占位符更新嵌套数组、嵌套文档集合

一、更新数组中的值 看如下students文档中的数据: db.students.insert({_id:NumberInt(1),grades:[NumberInt(80),NumberInt(85...
  • yaomingyang
  • yaomingyang
  • 2017年12月02日 17:16
  • 458

mongodb-更新操作符

修改器 1. $set 修改字段 更新字段值。 也可以改变字段值的类型。若字段不存在,则自动创建。 1.1. 字段存在:更新字段值 字段存在,更新字段值 db.collection.updat...
  • singzero
  • singzero
  • 2015年09月22日 13:30
  • 176

Mongodb常用操作语句

原文地址:http://dylanxu.iteye.com/blog/1404889 1、现有表以及数据添加字段 db.tbGoodsConsultant.update({}, {$set:{n...
  • tanga842428
  • tanga842428
  • 2016年12月28日 15:54
  • 980

MongoDB JAVA API更新数据示例

/** * MongoDBTest * MongoDB更新数据使用示例 */package com.labci.mongodb.test;import java.net.UnknownHostExce...
  • qq_16490557
  • qq_16490557
  • 2014年07月01日 09:21
  • 1540

MongoDB:管道操作

使用聚合框架可以对集合中的文档进行变换和组合。基本上,可以用多个构件创建一个管道(pipeline),用于对一连串的文档进行处理。这些构件包括筛选(filter)、投射(projecting)、分组(...
  • u012314976
  • u012314976
  • 2017年03月29日 10:00
  • 444

Mongodb字段更新$set操作符

一、定义 $set操作符替换掉指定字段的值 $set操作符有如下格式: { $set: { : , ... } } 使用点号指定一个内嵌文档的字段; 二、规则 如果指定字段不存在$set操...
  • yaomingyang
  • yaomingyang
  • 2017年12月13日 11:52
  • 581

java环境下:MongoDB的crud操作之Update (一)

最近由于项目的需要,接触了一下MongoDB 从最开始的cmd环境下操作,到客户端操作,然后是java语言操作数据库 下面记录一下我用java语言对数据库执行update操作: package com...
  • toxic5288
  • toxic5288
  • 2015年02月02日 15:12
  • 955

mongodb高级操作(1)-update

前面我们已经介绍了mongodb的基本操作:mongodb基本操作 下面是介绍一些高级的增删改查操作. 1.更新文档 文档替换 最简单的方法就是文档完全替换,如下就是一个完全替...
  • su377486
  • su377486
  • 2016年05月19日 00:50
  • 7757

mongodb基本操作方法

一、mongodb简介mongodb属于文档型数据库,储存的是文档(Bson->json的二进制化)。我们熟知的MYSQL数据库,它的数据是以表的形式储存的,每条记录都具有相同的结构,这样使得查询起来...
  • jession_lin
  • jession_lin
  • 2017年03月06日 16:41
  • 769

java使用MongoDB更新实体类某一字段的值

MongoDB中更新用updateAsset(entity),但是当只更新一个字段的时候,这样就会很慢,我们使用updateMulti()方法代码:Query query = new Query();...
  • u011974399
  • u011974399
  • 2017年12月12日 17:13
  • 171
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Mongodb 中常用的更新操作
举报原因:
原因补充:

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