Spring Data MongoDB 四:基本文档改动(update)(一)
Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)
一.简单介绍
Spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的update的操作,能够对在存储数据时是以键-值对的集合键是字符串,值能够是数据类型集合里的随意类型,包含数组和文档进行改动,我们今天介绍对基本文档的改动的方法、參数进行介绍。
我们对MongoDB的基本文档改动, MongoDB的查询语法:
>db.collection.update(
<query>,
<update>,
upsert:<boolean>,
multi:<boolean>
)
|
參数 |
类型 |
描写叙述 |
|
query |
document |
要改动哪些的查询条件。类似于SQL |
|
update |
document |
要改动的字段相应的值 |
|
upsert |
boolean |
可选的,默认值是false。假设依据查询条件没找到相应的文档。假设设置为true,相当于运行insert,假设设置为false,不做不论什么的操作。 |
|
multi |
boolean |
可选的,默认值是false。假设依据查询条件找到相应的多条记录是,假设设置为false时。仅仅改动第一条,假设设置为true,所有更新 |
我们SpringData MongoDB提供的相应的改动方法
1. mongoTemplate. updateFirst 改动符合条件第一条记录
2. mongoTemplate. updateMulti 改动符合条件的全部
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
3. mongoTemplate. Upsert 改动符合条件时假设不存在则加入
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
參数说明:
(1) Query : 要改动哪些的查询条件,类似于SQL 的 where
1) org.springframework.data.mongodb.core.query
2) org.springframework.data.mongodb.core.query.BasicQuery
这两个參数的差别和使用,在Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一) 有介绍过。就在详细介绍
(2) update
1) org.springframework.data.mongodb.core.query.Update
2) 子类org.springframework.data.mongodb.core.query.BasicUpdate
org.springframework.data.mongodb.core.query.BasicUpdate继承了org.springframework.data.mongodb.core.query.Update
Update提供了一些方法对基本文档进行操作
|
Spring MongoDB Update |
MongoDB |
描写叙述 |
|
Update rename (String oldName, String newName) |
$rename |
重命名字段 |
|
Update set (String key, Object value) |
$set |
用来指定一个键的值,假设不存在则创建它 |
|
Update unset (String key) |
$unset |
用来指定一个键的值。假设不存在不创建创建它 |
BasicUpdate继承了update方法,BasicUpdate构造參数能够自己实现update SQL 语句
1)BasicUpdate(DBObjectupdate Object) Object是JSON格式
2)BasicUpdate(java.lang.StringupdateString)
BasicUpdate须要手动实现$set等操作符SQL语句,也能够使用Update的一些操作改动文档的操作方法,由于继承了Update类
二.mongoTemplate.Upsert 操作
mongoTemplate. Upsert 改动符合条件时假设不存在则加入
1.对改动符合条件时假设不存时操作
第一步:我们查询条件onumber=001的cname进行改动。Spring DataMongoDB代码实现
mongoTemplate.upsert(newQuery(Criteria.where("onumber").is("001")), newUpdate().set("cname", "zcy"), collectionName);
第二步:我们先查询MongoDB数据
>db.orders.find({"onumber":"001"})
>
第三步:我们运行mongoTemplate.upsert操作
第四步:查询MongoDB数据:
>db.orders.find({"onumber":"001"})
{ "_id" : ObjectId("55c5673e28121ca9e1dd397f"),"onumber" : "001", "cname" : "zcy" }
改动符合条件时假设不存在则加入,相当于运行了insert
2. 对改动符合条件时存在时,改动字段不存在的操作
第一步:Spring Data MongoDB代码没改变
第二步:我们先查询MongoDB数据 :
> db.orders.find({"onumber":"001"})
{ "_id" : ObjectId("55c5689727e0a66301f9bb51"),"onumber" : "001" }
第三步: 我们运行mongoTemplate.upsert操作
第四步:然后在查询MongoDB数据:
>db.orders.find({"onumber":"001"})
{ "_id" : ObjectId("55c5689727e0a66301f9bb51"),"onumber" : "001", "cname" : "zcy" }
相当于运行了MongoDB的:
>db.orders.update(
{"onumber" :"001"},
{$set: { "cname " : "zcy2"} },
true,
true
)
验证了 mongoTemplate. Upsert 改动符合条件时假设不存在则加入
三.mongoTemplate. updateFirst
mongoTemplate. updateFirst 改动符合条件第一条记录
1. 对改动符合条件时多条记录的操作
第一步: 我们查询条件cname=zcy 的date进行改动,Spring Data MongoDB代码实现
mongoTemplate. updateFirst (newQuery(Criteria.where("cname").is("zcy ")), newUpdate().set("date", "2015-08-08"), collectionName);
第二步:我们先查询MongoDB数据
第三步:运行mongoTemplate. updateFirst操作
第四步:然后在查MongoDB数据:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
四.mongoTemplate. updateMulti
mongoTemplate.updateMulti改动符合条件的全部
1. 对改动符合条件时多条记录的操作
第一步:我们查询条件cname=zcy 的date进行改动。Spring Data MongoDB代码实现
mongoTemplate. updateMulti (newQuery(Criteria.where("cname").is("zcy ")), newUpdate().set("date", "2015-08-08"), collectionName);
第二步: 我们先查询MongoDB数据
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
第三步:运行mongoTemplate. updateMulti操作
第四步:查询MongoDB数据:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
改动符合条件的全部数据文档
四.BasicUpdate操作
BasicUpdate JSON格式。须要我们自己实现update SQL,BasicUpdate须要手动实现$set等操作符SQL语句,也能够使用Update的一些操作改动文档的操作方法,由于继承了Update类
mongoTemplate.updateFirst 改动符合条件第一条记录
第一步:对改动符合条件时多条记录的操作时。我们查询条件cname=zcy 的date进行改动,Spring Data MongoDB代码实现
BasicDBObject basicDBObject=new BasicDBObject();
basicDBObject.put("$set", new BasicDBObject("date","2015-08-09"));
Updateupdate=newBasicUpdate(basicDBObject);
mongoTemplate.updateFirst(new Query(Criteria.where("cname").is("zcy")), update,collectionName);
第二步:查询MongoDB的数据
第三步:运行mongoTemplate.updateFirst 操作。
第四步:查询MongoDB数据
basicDBObject能够同一时候对多个字段进行改动
今天介绍了对主要的文档的改动,仅仅对Update set (String key, Object value)操作。其它的操作符能够參考学习MongoDB 二:MongoDB加入、删除、改动。我们今天主要介绍了改动方法,其它的操作跟set
方法几乎相同,所以就没具体一个一个介绍过去。
Spring Data MongoDB 四:基本文档改动(update)(一)的更多相关文章
- Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)
Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...
- Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)
一.简单介绍 Spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一 ...
- Spring Data MongoDB 三:基本文档查询(Query、BasicQuery
一.简介 spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...
- Spring data mongodb 聚合,投射,内嵌数组文档分页.
尽量别直接用 DBObject ,Spring data mongodb 的api 本来就没什么多大用处,如果还直接用 DBObject 那么还需要自己去解析结果,说动做个对象映射,累不累 Spri ...
- spring data mongodb 配置遇到的几个问题
一. mongodb 2.2版本以上的配置 spring.data.mongodb.uri = mongodb://newlook:newlook@192.168.0.109:27017/admin ...
- SpringMVC MongoDB之“基本文档查询(Query、BasicQuery)”
一.简介 spring Data MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...
- spring data mongodb中,如果对象中的属性不想加入到数据库字段中
spring data mongodb中,如果对象中的属性不想加入到数据库字段中,可加@Transient注解,声明为透明属性 spring data mongodb 官网帮助文档 http://ww ...
- 使用Spring访问Mongodb的方法大全——Spring Data MongoDB查询指南
1.概述 Spring Data MongoDB 是Spring框架访问mongodb的神器,借助它可以非常方便的读写mongo库.本文介绍使用Spring Data MongoDB来访问mongod ...
- Spring Boot属性文件配置文档(全部)
This sample file is meant as a guide only. Do not copy/paste the entire content into your applicatio ...
随机推荐
- java面试题之wait(),notify()和suspend(),resume()之间的区别
wait()方法和notify()方法的区别: 这两个方法都是属于Object类中的,也是配套使用的,当调用这两个方法阻塞时要释放占用的锁,而锁是任何对象都具有的,调用任意对象的wait()方法导致线 ...
- linux安装websocketd服务
1.下载 wget https://github.com/joewalnes/websocketd/releases/download/v0.3.0/websocketd-0.3.0-linux_am ...
- 在vue路由当中使用keep-alive避免多次加载组件,减少消耗
今天在vue当中使用了full-page这个组件.但是发现在每次路由跳转完之后,再回到使用fullpage的这个页面,fullpage会报错,fullpage只能初始化一次. 这个时候给路由使用kee ...
- Entity Framework表名默认自动变为复数形式等常见问题解决方法
今天使用了一下手写EntityFramework,发现一些常见的问题,做个记录: 1.以前使用模板生成不太在意的问题,就是在定义实体类时,如果没映射注释,自动映射的表名会变成复数形式 如:表名==&g ...
- MongoDB管理与监控
https://blog.csdn.net/Chen_Victor/article/details/74855050 https://www.cnblogs.com/zhangyinguang/p/5 ...
- ScrollView 嵌套WebView 的问题优化
一.布局样式 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:androi ...
- FMDB支持的事务类型
FMDB支持的事务类型 在数据库中,事务可以保证数据操作的完整性.当存在大量并发操作,容易出现死锁问题.在SQLite中,为了解决该问题,提供三种事务模式,分别为DEFFERED.IMMEDIAT ...
- HAXM 6.0.5显示不兼容Windows
HAXM 6.0.5显示不兼容Windows 最近更新Android后,用户会在Android Manager中发现,以前可以安装Intel x86模拟器现在不能安装了.提示错误信息如下:intel ...
- error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools":解决方案
我是在安装scrapy时遇到这个问题的,安装其他组件也可能会遇到.但问题解决办法都是大致相同的. 以安装scrapy为例: 在pycharm中安装twisted时出现: error: Microsof ...
- P2P技术简介(包括BT软件的分析)(转)
这是一篇别人发表的论文,里面很全面的解释了P2P技术的实现,以及BT网络中应用P2P技术所设计的原理,并列举BT软件的一些专业名词的定义.由于论文发表的比较早,2005年时还没有DHT技术. (链接: ...