建立儲存庫實例

本節涵蓋如何為已定義的儲存庫介面建立實例和 Bean 定義。

Java 設定

在 Java 設定類別上使用特定於儲存區的 @EnableCouchbaseRepositories 註解,以定義儲存庫啟動的設定。如需 Spring 容器的基於 Java 的設定簡介,請參閱 Spring 參考文件中的 JavaConfig

啟用 Spring Data 儲存庫的範例設定如下

基於註解的儲存庫組態範例
@Configuration
@EnableJpaRepositories("com.acme.repositories")
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // …
  }
}
先前的範例使用特定於 JPA 的註解,您應根據您實際使用的儲存區模組進行變更。這同樣適用於 EntityManagerFactory Bean 的定義。請參閱涵蓋特定於儲存區的組態章節。

XML 設定

每個 Spring Data 模組都包含一個 repositories 元素,可讓您定義 Spring 為您掃描的基礎套件,如下列範例所示

透過 XML 啟用 Spring Data 儲存庫
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns:beans="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://www.springframework.org/schema/data/jpa"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
    https://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/data/jpa
    https://www.springframework.org/schema/data/jpa/spring-jpa.xsd">

  <jpa:repositories base-package="com.acme.repositories" />

</beans:beans>

在先前的範例中,指示 Spring 掃描 com.acme.repositories 及其所有子套件,以尋找擴充 Repository 或其子介面之一的介面。對於找到的每個介面,基礎架構會註冊特定於持久性技術的 FactoryBean,以建立處理查詢方法調用的適當代理。每個 Bean 都以從介面名稱衍生的 Bean 名稱註冊,因此 UserRepository 的介面將在 userRepository 下註冊。巢狀儲存庫介面的 Bean 名稱以其封閉類型名稱作為前綴。基礎套件屬性允許使用萬用字元,以便您可以定義掃描套件的模式。

使用篩選器

預設情況下,基礎架構會挑選每個擴充特定於持久性技術的 Repository 子介面,且位於設定的基礎套件下的介面,並為其建立 Bean 實例。但是,您可能希望更精細地控制為哪些介面建立 Bean 實例。若要執行此操作,請在儲存庫宣告內使用篩選器元素。語意與 Spring 元件篩選器中的元素完全等效。如需詳細資訊,請參閱 Spring 參考文件,以取得這些元素的資訊。

例如,若要從作為儲存庫 Bean 的實例化中排除某些介面,您可以使用下列組態

使用篩選器
  • Java

  • XML

@Configuration
@EnableCouchbaseRepositories(basePackages = "com.acme.repositories",
    includeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeRepository") },
    excludeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeOtherRepository") })
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // …
  }
}
<repositories base-package="com.acme.repositories">
  <context:include-filter type="regex" expression=".*SomeRepository" />
  <context:exclude-filter type="regex" expression=".*SomeOtherRepository" />
</repositories>

先前的範例包含所有以 SomeRepository 結尾的介面,並排除那些以 SomeOtherRepository 結尾的介面被實例化。

獨立用法

您也可以在 Spring 容器外部使用儲存庫基礎架構,例如,在 CDI 環境中。您仍然需要在類別路徑中包含一些 Spring 程式庫,但一般而言,您也可以以程式方式設定儲存庫。提供儲存庫支援的 Spring Data 模組隨附特定於持久性技術的 RepositoryFactory,您可以如下方式使用

儲存庫工廠的獨立用法
RepositoryFactorySupport factory = … // Instantiate factory here
UserRepository repository = factory.getRepository(UserRepository.class);