Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)

学习MongoDB 二:MongoDB加入、删除、改动

一.简单介绍

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
的 where

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)(一)的更多相关文章

  1. Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)

    Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...

  2. Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)

    一.简单介绍 Spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一 ...

  3. Spring Data MongoDB 三:基本文档查询(Query、BasicQuery

    一.简介 spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...

  4. Spring data mongodb 聚合,投射,内嵌数组文档分页.

    尽量别直接用 DBObject  ,Spring data mongodb 的api 本来就没什么多大用处,如果还直接用 DBObject 那么还需要自己去解析结果,说动做个对象映射,累不累 Spri ...

  5. spring data mongodb 配置遇到的几个问题

    一. mongodb 2.2版本以上的配置 spring.data.mongodb.uri = mongodb://newlook:newlook@192.168.0.109:27017/admin ...

  6. SpringMVC MongoDB之“基本文档查询(Query、BasicQuery)”

    一.简介 spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一篇我 ...

  7. spring data mongodb中,如果对象中的属性不想加入到数据库字段中

    spring data mongodb中,如果对象中的属性不想加入到数据库字段中,可加@Transient注解,声明为透明属性 spring data mongodb 官网帮助文档 http://ww ...

  8. 使用Spring访问Mongodb的方法大全——Spring Data MongoDB查询指南

    1.概述 Spring Data MongoDB 是Spring框架访问mongodb的神器,借助它可以非常方便的读写mongo库.本文介绍使用Spring Data MongoDB来访问mongod ...

  9. Spring Boot属性文件配置文档(全部)

    This sample file is meant as a guide only. Do not copy/paste the entire content into your applicatio ...

随机推荐

  1. JAVA Apache POI 之sax 解析10万级大数量数据

    第一步让我们来看看我们的大量数据的excel 文件 好的下面第二步看一下代码: package com.chinait.utils; /** * 写这个东西主要是最近做了一个联通的数据迁移工作,他们就 ...

  2. jump 转换进制+dp

    from Contest1024 - 省选模拟题14 题目大意 MMM站在x=0的地方,她想跳到x=t的地方.MMM每次跳跃可以选择跳到x - k或者x + k的地方,其中k={base^n | ba ...

  3. 20140323组队赛 2012福建省第三届ACM省赛题目

    A - Solve equation Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u ...

  4. batch.bat explaination

    1.Echo 命令 打开回显或关闭请求回显功能,或显示消息.如果没有任何参数,echo 命令将显示当前回显设置. 语法 echo [{on|off}] [message] Sample篅echo of ...

  5. py2exe使用方法 (含一些调试技巧,如压缩email 类)

    http://justcoding.iteye.com/blog/900993 一.简介 py2exe是一个将python脚本转换成windows上的可独立执行的可执行程序(*.exe)的工具,这样, ...

  6. Scrapy学习-13-使用DownloaderMiddleware设置IP代理池及IP变换

    设置IP代理池及IP变换方案 方案一: 使用国内免费的IP代理 http://www.xicidaili.com # 创建一个tools文件夹,新建一个py文件,用于获取代理IP和PORT from ...

  7. hdu 4932 /bestcoder B题 #4 /思维题

    题意:给一个数列(整数),用一些不相交的区间去覆盖(只能是用端点去覆盖,端点可以交).而且区间出度相等.求最大区间长度. 开始一下就敲了,枚举每个区间长度,判断合法,更新最大.但是后来一看小数,感觉不 ...

  8. OS | Process

    linux多进程 1. fork()创建进程,创建一份父进程的拷贝:在父进程中返回的是子进程id,在子进程中返回的是0:失败时返回-1: 2. fork()经常和exec()结合,exec() 覆盖了 ...

  9. bitShark对Android版本的支持

    bitShark对Android版本的支持   bitShark是一款轻量级的Android数据抓包软件.使用该软件,可以随时随地抓取网络中的各种数据包,并进行各项分析.我们推出的bitShark手机 ...

  10. Oracle if else 、case when 判断示例

    declare -- 声明奖金的变量 v_comm emp.comm%type; begin -- 查询出员工的奖金 select comm into v_comm from emp where em ...