Spring Data访问Elasticsearch----创建存储库实例

Spring Data访问Elasticsearch----创建存储库实例

本文介绍如何为已定义的存储库接口创建实例和bean定义。

一、Java配置

在Java配置类上使用特定于存储的@EnableElasticsearchRepositories注解来定义用于存储库激活的配置。有关基于java的Spring容器配置的介绍,请参阅Spring参考文档中的JavaConfig。启用Spring Data存储库的样例配置如下:
基于注解的存储库配置样例

java 复制代码
@Configuration
@EnableJpaRepositories("com.acme.repositories")
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // ...
  }
}

前面的示例使用特定于jpa的注解,你可以根据实际使用的存储模块对其进行更改。这同样适用于EntityManagerFactory bean的定义。请参阅介绍特定于存储的配置的部分。

二、XML配置

每个Spring Data模块都包含一个存储库元素,允许你定义Spring扫描的基本包,如下面的示例所示:
通过XML启用Spring Data存储库

xml 复制代码
<?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名称以其enclosing类型名称为前缀。基础包属性允许使用通配符,以便你可以定义扫描包的pattern。

三、使用过滤器

默认情况下,基础结构会拾取位于配置的基础包下的每个扩展持久性技术特定的Repository子接口的接口,并为其创建一个bean实例。但是,你可能需要更细粒度地控制为哪些接口创建bean实例。为此,请在存储库声明中使用过滤器元素。语义与Spring的组件过滤器中的元素完全等效。有关详细信息,请参阅这些元素的Spring参考文档

例如,要将某些接口从存储库bean实例化中排除,可以使用以下配置:
使用过滤器

java 复制代码
@Configuration
@EnableElasticsearchRepositories(basePackages = "com.acme.repositories",
    includeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeRepository") },
    excludeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeOtherRepository") })
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // ...
  }
}

前面的示例包括以SomeRepository结尾的所有接口,并从实例化中排除以SomeOtherRepository结尾的接口。

四、独立使用

你还可以在Spring容器之外使用存储库基础结构 --- 例如在CDI环境中。类路径中仍然需要一些Spring库,但通常也可以通过编程设置存储库。提供存储库支持的Spring Data模块附带了一个特定于持久性技术的RepositoryFactory,你可以使用它,如下所示:
存储库工厂的独立使用

java 复制代码
RepositoryFactorySupport factory = ... // Instantiate factory here
UserRepository repository = factory.getRepository(UserRepository.class);
相关推荐
努力学习的明42 分钟前
Spring MVC 对 JavaWeb 的优化:从核心组件到注解
java·spring·mvc·web
数巨小码人2 小时前
Linux常见命令
大数据·linux·运维·服务器·elasticsearch·搜索引擎
木梓辛铭2 小时前
Spring Cache的详细使用
java·后端·spring
就不爱吃大米饭2 小时前
Chrome代理IP配置教程常见方式附问题解答
大数据·人工智能·搜索引擎
bing_1583 小时前
Spring MVC 拦截器 (HandlerInterceptor) 是什么? 它与 Servlet Filter 有什么区别?
spring·servlet·mvc
真实的菜4 小时前
Elasticsearch 分片机制高频面试题(含参考答案)
elasticsearch·搜索引擎·es
长勺5 小时前
Spring Security vs Shiro vs Sa-Token
java·后端·spring
ice___Cpu5 小时前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
tebukaopu1485 小时前
官方 Elasticsearch SQL NLPChina Elasticsearch SQL
大数据·sql·elasticsearch
uyeonashi7 小时前
【Boost搜索引擎】构建Boost站内搜索引擎实践
开发语言·c++·搜索引擎