【Spring连载】使用Spring Data的Repositories----核心概念Core concepts

本文主要是介绍【Spring连载】使用Spring Data的Repositories----核心概念Core concepts,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【Spring连载】使用Spring Data的Repositories----核心概念Core concepts

    • 实体状态检测策略

Spring Data存储库抽象中的中心接口是Repository。它使用要管理的域类以及域类的标识符类型作为类型参数。此接口主要充当标记接口,用于捕获要使用的类型,并帮助您发现扩展此类型的接口。CrudRepository和ListCrudRepository接口为被管理的实体类提供了复杂的CRUD功能。
CrudRepository接口

public interface CrudRepository<T, ID> extends Repository<T, ID> {<S extends T> S save(S entity);      -----1Optional<T> findById(ID primaryKey); -----2Iterable<T> findAll();               -----3long count();                        -----4void delete(T entity);               -----5boolean existsById(ID primaryKey);   -----6// … more functionality omitted.
}1. 保存给定的实体。
2. 返回由给定ID标识的实体。
3. 返回所有实体。
4. 返回实体个数。
5. 删除给定的实体。
6. 返回是否存在具有给定ID的实体

此接口中声明的方法通常称为CRUD方法。ListCrudRepository提供了等效的方法,但它们返回List,而CrudRepository方法返回一个Iterable。
框架还提供特定于持久性技术的抽象,如JpaRepository或MongoRepository。这些接口继承了CrudRepository,除了相当通用的与持久性技术无关的接口(如CrudRepository)之外,还公开了底层持久性技术的功能。
除了CrudRepository之外,还有PagingAndSortingRepository 和ListPagingAndSortingRepository,它们添加了其他方法来简化对实体的分页访问:
PagingAndSortingRepository接口

public interface PagingAndSortingRepository<T, ID>  {Iterable<T> findAll(Sort sort);Page<T> findAll(Pageable pageable);
}

扩展接口(Extension interfaces)以实际存储模块支持为准。在本文档解释一般方案的同时,请确保你的存储模块支持要使用的接口。
要访问页面大小为20的User的第二个页面,你可以执行以下操作:

PagingAndSortingRepository<User, Long> repository = // … get access to a bean
Page<User> users = repository.findAll(PageRequest.of(1, 20));

ListPagingAndSortingRepository提供了等效的方法,但返回了一个List,而PagingAndSortingRepository方法返回一个Iterable。
除了查询方法之外,还提供了计数查询和删除查询。以下列表显示了计数查询的接口定义:
计数查询

interface UserRepository extends CrudRepository<User, Long> {long countByLastname(String lastname);
}

下面的清单显示了删除查询的接口定义:
删除查询

interface UserRepository extends CrudRepository<User, Long> {long deleteByLastname(String lastname);List<User> removeByLastname(String lastname);
}

实体状态检测策略

下表描述了Spring Data提供的用于检测实体是否为新实体的策略:
表1:在Spring Data中用于检测实体是否为新实体的选项

检测方法方法描述
@Id-Property检查(默认)默认情况下,Spring Data检查给定实体的标识符属性。如果标识符属性为null或在基本类型的情况下为0,则假定该实体是新的。否则,它被认为不是新的。
@Version-Property检查如果带有@Version注释的属性存在并且为空,或者在原始类型为0的版本属性的情况下,该实体被认为是新的。如果版本属性存在,但具有不同的值,则认为该实体不是新实体。如果没有版本属性,Spring Data将返回到检查标识符属性。
实现Persistable如果一个实体实现了Persistable, Spring Data将新检测委托给该实体的isNew(…)方法。有关详细信息,请参阅Javadoc。注意:如果你使用AccessType.PROPERTY, Persistable的属性将被检测和持久化。为了避免这种情况,使用@Transient。
提供自定义EntityInformation实现你可以通过创建特定于模块的repository工厂的子类,并覆盖getEntityInformation(…)方法来定制EntityInformation抽象,这会用于repository 基础实现。然后必须将特定于模块的repository工厂的自定义实现注册为Spring bean。注意,这应该很少见的。

这篇关于【Spring连载】使用Spring Data的Repositories----核心概念Core concepts的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/749967

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数