Spring Data访问 MongoDB(十五)----MongoDB特有的数据操作方法

【Spring连载】使用Spring Data访问 MongoDB(十五)----MongoDB特有的数据操作方法

除了 查询方法之外,还可以使用专门的方法更新数据。

一、更新方法

你还可以使用上表中的关键字创建查询,以标识匹配的文档,以便对其运行更新。实际的更新操作是由方法本身的@Update注解定义的,如下所示。请注意,派生查询的命名模式以find开头。正在使用update(如updateAllByLastname(...​)) 仅允许与@Query组合使用。

更新将应用于所有匹配的文档,并且无法通过传递Page或使用任何limit关键字来限制范围。返回类型可以是void,也可以是数字类型,例如long,以容纳修改后的documents数。
例1:更新方法

java 复制代码
public interface PersonRepository extends CrudRepository<Person, String> {

    @Update("{ '$inc' : { 'visits' : 1 } }")
    long findAndIncrementVisitsByLastname(String lastname); --------1

    @Update("{ '$inc' : { 'visits' : ?1 } }")
    void findAndIncrementVisitsByLastname(String lastname, int increment); --------2

    @Update("{ '$inc' : { 'visits' : ?#{[1]} } }")
    long findAndIncrementVisitsUsingSpELByLastname(String lastname, int increment); --------3

    @Update(pipeline = {"{ '$set' : { 'visits' : { '$add' : [ '$visits', ?1 ] } } }"})
    void findAndIncrementVisitsViaPipelineByLastname(String lastname, int increment); --------4

    @Update("{ '$push' : { 'shippingAddresses' : ?1 } }")
    long findAndPushShippingAddressByEmail(String email, Address address); --------5

    @Query("{ 'lastname' : ?0 }")
    @Update("{ '$inc' : { 'visits' : ?1 } }")
    void updateAllByLastname(String lastname, int increment); --------6
}

1. 更新的筛选器查询是从方法名称派生的。更新是"按原样"进行的,不绑定任何参数。
2. 实际的增量值由绑定到?1占位符的increment方法参数定义。
3. 使用Spring表达式语言(SpEL)进行参数绑定。
4. 使用管道(pipeline)属性可以发布聚合管道更新。
5. 更新可能包含复杂的对象。
6. 将基于字符串的查询与更新相结合。

存储库更新不会发出持久化事件或映射生命周期事件。

二、删除方法

上表中的关键字可以与delete...By或remove...By结合使用,以创建删除匹配documents的查询。
Delete...By查询

java 复制代码
public interface PersonRepository extends MongoRepository<Person, String> {

    List <Person> deleteByLastname(String lastname);    --------1  

    Long deletePersonByLastname(String lastname);       --------2  

    @Nullable
    Person deleteSingleByLastname(String lastname);     --------3  

    Optional<Person> deleteByBirthdate(Date birthdate); --------4  
}

1. 在实际删除所有匹配的文档之前,使用返回类型List检索并返回这些documents。
2. 数字返回类型直接删除匹配的documents,返回删除的documents总数。
3. 单个域类型的结果检索并删除第一个匹配的document。
4. 与3中相同,但包装在可选类型中。
相关推荐
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
通过java后端代码来实现给word内容补充格式文本内容控件,以及 设置控件的标记和标题
java·c#·word
無限進步D2 小时前
Java 面向对象高级 接口
java·开发语言
逸Y 仙X2 小时前
文章二十七:ElasticSearch ES查询模板(Search Template)高效复用实战
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
二哈赛车手3 小时前
新人笔记---Spring AI的Advisor以及其底层机制讲解(涉及源码),包含一些遇见的Spring AI的Advisor缺陷问题的解决方案
java·人工智能·spring boot·笔记·spring
薪火铺子3 小时前
Redis 缓存三大问题与解决方案
redis·spring·缓存
AC赳赳老秦3 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
两年半的个人练习生^_^3 小时前
Java日志框架和使用、日志记录规范
java·开发语言·开发规范
pq2173 小时前
最简单的理解synchronized锁升级
java
杨凯凡3 小时前
【032】排查入门:jstack、heap dump、Arthas 初识
java·开发语言·后端