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);      -----1

  Optional<T> findById(ID primaryKey); -----2

  Iterable<T> findAll();               -----3

  long count();                        -----4

  void delete(T entity);               -----5

  boolean 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。注意,这应该很少见的。
  • 13
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值