为单一的repositories添加自定义方法

为了通过自定义方法来丰富repository,首先要定义一个接口和一个接口的实现类。

Example 15. Interface for custom repository functionality(自定义接口)

  1. interface UserRepositoryCustom {
  2. public void someCustomMethod(User user);
  3. }

Example 16. Implementation of custom repository functionality(接口的实现类)

  1. class UserRepositoryImpl implements UserRepositoryCustom {
  2. public void someCustomMethod(User user) {
  3. // Your custom implementation
  4. }
  5. }

接口的实现类名字后缀必须为impl才能在扫描包时被找到。

实现类本身并不依赖于Spring Data,就是一个普通的Srping的bean,所以可以是用标准的依赖注入在其中注入其它相关的bean,比如JdbcTemplate等等。

Example 17. Changes to the your basic repository interface(修改基础的repository接口)

  1. interface UserRepository extends CrudRepository<User, Long>, UserRepositoryCustom {
  2. // Declare query methods here
  3. }

上面代码在让标准的repository接口继承了自定义的接口,将标准的CRUD和自定义的方法结合到了一起。

配置

在使用Xml配置时,Spring框架会自动检测指定包路径下的实现类。实现类的后缀必须满足属性repository-impl-postfix的定义,默认后缀是Impl

  1. <repositories base-package="com.acme.repository" />
  2. <repositories base-package="com.acme.repository" repository-impl-postfix="FooBar" />

在第一个配置中,spring会找到类com.acme.repository.UserRepositoryImpl,而在第二个配置中,spring会尝试查找com.acme.repository.UserRepositoryFooBar

人工装载

上面的例子使用了基于注解的配置来自动装载。如果自定义的实现类需要特殊的装载,也可以手动的声明一个bean,名字要遵循上一节定义的命名规范。

Example 19. Manual wiring of custom implementations(人工装载自定义的实现类)

  1. <repositories base-package="com.acme.repository" />
  2. <beans:bean id="userRepositoryImpl" class="...">
  3. <!--其他配置 -->
  4. </beans:bean