spring data elasticsearch 使用
很久之前就安装了elasticsearch,一直没用java用过,最近看了一下spring data系列的elasticsearch,这里写一篇心得。
如果尚未安装elasticsearch,可以 参考https://www.cnblogs.com/shaozm/p/8732842.html这篇文章。
一 、原生写法
连接客户端
先谈谈原生的写法,
private TransportClient client;
public TransportClient getClient(){
Settings setting = Settings.builder()
.put("cluster.name", "elas_cluster")
.put("client.transport.ignore_cluster_name", true)
// .put("client.transport.nodes_sampler_interval", 5) //
.put("client.transport.sniff", true)
.build(); client = new PreBuiltTransportClient(setting)
.addTransportAddress(
new TransportAddress(new InetSocketAddress("192.168.0.2",9300))
);
return client; }
首先连接客户端,这里单节点和集群写法一致,如果是集群的话也只需配置master节点,官方说法是客户端开启嗅探之后,会把嗅探到的节点列表把本地覆盖掉。
搜索
因为我是用spring data elasticsearch框架导入的数据,所以这里就不写index, type的创建,就展示一下搜索的写法。
public void search(){
QueryBuilder queryBuilder= QueryBuilders.boolQuery()
.must(QueryBuilders.matchQuery("newsTitle","首个电商俱乐部"))
.must(QueryBuilders.matchQuery("newsCate","科技"));
SearchResponse response= client.prepareSearch("test")
.setTypes("newsArticle")
.setQuery(queryBuilder).get();
SearchHits searchHits = response.getHits();
for(SearchHit searchHit : searchHits) {
System.out.println(searchHit);
}
client.close();
}
基本搜索解析
这里先谈一下基本的搜索
elasticsearch 搜索请求是restful风格的,它的搜索请求都是根据 json格式的参数去搜索的。
一般来说 elasticsearch 的普通搜索json都是类似 { "query" : ... } 这样的,
首先elasticsearch 的所有搜索基本分成两种,一个是 过滤 ,一种是查询 (为了区分我这里称得分搜索) ,它们区别举例说明
像过滤搜索判断都是直接判断符不符合,比如是不是这个年龄范围的,这个字段是不是匹配的,是就返回,不是就不返回,
而得分搜索有一个score分数作为返回依据,比如这个字段匹配的,给你一点分数,那个字段没匹配,没分数,综合所有的分数看是不是达标了,达标了返回,不达标不返回。
类似
{ "query" : {“range” : { ....... }} }
{ "query" : {“term” : { ....... }} } term是精确查询,需要完全匹配
属于过滤搜索
{ "query" : {“match” : { ....... }} }
{ "query" : {“bool” : { ....... }} }
属于得分搜索
而像{ "query" : {“bool” : { ....... }} } 这种是组合多个查询的,其中........ 的内容可以是多个must 或者should或者must_not或者filter的组合,最终计算score
二、spring data elasticsearch
准备工作
现在可以进入主题了,spring data elasticsearch的用法
先导包
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-elasticsearch</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
接着配置yml
spring:
data:
elasticsearch:
repositories:
enabled: true
cluster-nodes: 192.168.0.2:9300
cluster-name: elas_cluster
异常
这里说一个bug,如果有redis你可能会抛异常,我这里是在启动类里配置了这么一行
public static void main(String[] args) throws Exception{
System.setProperty("es.set.netty.runtime.available.processors", "false");
SpringApplication.run(EsStart.class,args);
}
使用详解
spring-data系列的框架,用过jpa的应该都知道套路
首先配置实体注解
@Document(indexName = "test",type = "newsArticle")
public class NewsArticlePO {
......
}
如果有什么字段需要分词器,可以单独在字段上配置
。。。。。。
@Field(type = FieldType.Text, analyzer = "ik_max_word",searchAnalyzer = "ik_max_word")
private String newsTitle;
。。。。。。
这时候一启动项目就会发现index,type已经自动生成了 第二步 创建repository
public interface ArticleRepository extends ElasticsearchRepository<NewsArticlePO,Long> {
。。。。。。
}
这里有几种做法,一个是自己利用名字规则定义新的方法,一个是用query注解创建查询,一个是使用父类继承的方法。 第一种方法 在 ArticleRepository中创建方法
/**
* 根据标题,类别两个字段搜索
* */
List<NewsArticlePO> findByNewsTitleAndAndNewsCate(String newsTitle,String newsCate);
具体规则参考spring data elasticsearch的官方文档附录 第二种方法
在 ArticleRepository中创建方法
@Query("{\"bool\": {\"must\": [{ \"match\": { \"newsTitle\": \"?0\"}},{ \"match\": { \"newsCate\": \"?1\"}}]}}")
List<NewsArticlePO> findByQuery(String newsTitle, String newsCate);
第三种方法
在service层代码或者其他类中注入 ArticleRepository
@Resource
private ArticleRepository articleRepository;
创建方法
public Page<NewsArticlePO> searchBuild(String newsTitle, String newsCate) {
QueryBuilder queryBuilder= QueryBuilders.boolQuery()
.must(QueryBuilders.matchQuery("newsTitle",newsTitle))
.must(QueryBuilders.matchQuery("newsCate",newsCate));
SearchQuery searchQuery = new NativeSearchQueryBuilder()
.withQuery(queryBuilder)
.build();
return articleRepository.search(searchQuery);
}
这就ok了,如果不喜欢使用repository也没事,可以注入ElasticsearchTemplate
@Resource
private ElasticsearchTemplate elasticsearchTemplate;
public List<NewsArticlePO> searchTemplate(String newsTitle, String newsCate){
QueryBuilder queryBuilder= QueryBuilders.boolQuery()
.must(QueryBuilders.matchQuery("newsTitle",newsTitle))
.must(QueryBuilders.matchQuery("newsCate",newsCate)); SearchQuery searchQuery = new NativeSearchQueryBuilder()
.withQuery(queryBuilder)
.build();
return elasticsearchTemplate.queryForList(searchQuery,NewsArticlePO.class);
}
甚至可以通过elasticsearchTemplate.getClient()得到原生的client进行操作
demo项目地址 https://github.com/1160809039/elasticsearch-demo
spring data elasticsearch 使用的更多相关文章
- elasticsearch系列七:ES Java客户端-Elasticsearch Java client(ES Client 简介、Java REST Client、Java Client、Spring Data Elasticsearch)
一.ES Client 简介 1. ES是一个服务,采用C/S结构 2. 回顾 ES的架构 3. ES支持的客户端连接方式 3.1 REST API ,端口 9200 这种连接方式对应于架构图中的RE ...
- Elasticsearch基本用法(2)--Spring Data Elasticsearch
Spring Data Elasticsearch是Spring Data项目下的一个子模块. 查看 Spring Data的官网:http://projects.spring.io/spring-d ...
- Elasticsearch Java client(ES Client 简介、Java REST Client、Java Client、Spring Data Elasticsearch)
elasticsearch系列七:ES Java客户端-Elasticsearch Java client(ES Client 简介.Java REST Client.Java Client.Spri ...
- Spring Boot + Spring Data + Elasticsearch实例
Spring Boot + Spring Data + Elasticsearch实例 学习了:https://blog.csdn.net/huangshulang1234/article/detai ...
- elasticsearch 拼音+ik分词,spring data elasticsearch 拼音分词
elasticsearch 自定义分词器 安装拼音分词器.ik分词器 拼音分词器: https://github.com/medcl/elasticsearch-analysis-pinyin/rel ...
- How to provide highlighting with Spring data elasticsearch
How to provide highlighting with Spring data elasticsearch @Test public void shouldReturnHighlighted ...
- springboot集成spring data ElasticSearch
ES支持SpringBoot使用类似于Spring Data Jpa的方式查询,使得查询更加方便. 1.依赖引入 compile “org.springframework.boot:spring-bo ...
- 031 Spring Data Elasticsearch学习笔记---重点掌握第5节高级查询和第6节聚合部分
Elasticsearch提供的Java客户端有一些不太方便的地方: 很多地方需要拼接Json字符串,在java中拼接字符串有多恐怖你应该懂的 需要自己把对象序列化为json存储 查询到结果也需要自己 ...
- SpringBoot整合Spring Data Elasticsearch
Spring Data Elasticsearch提供了ElasticsearchTemplate工具类,实现了POJO与elasticsearch文档之间的映射 elasticsearch本质也是存 ...
随机推荐
- CC2530 LED灯控制
有三个寄存器 分别是功能寄存器.方向寄存器.配置寄存器 功能寄存器 通用 I/O口 说的就是一般的I/O口,可以输出高低电平 为外设IO 例如摄像头或者打印机他们具体实现某些功能(拍照或打印文档) ...
- CentOS7.4 Keepalived+LVS 负载均衡 后台节点健康检查
主机信息 VIP 10.10.10.55 LVS01 10.10.10.59 Web01 10.10.10.60 Web02 10.10.10.61 一.apache简单配置 1.(10.10.10. ...
- linux man指令问题
linux man指令问题 2010-1-13 13:33 提问者: 钟离伊轩 man命令执行时,可加入数值,来限制帮助级别. 这句话对不对啊???? 我记得man page是分章节的..好像可以加数 ...
- [原]外网访问用azure虚拟机搭建的网站
1.Ubuntu+Apache+PHP的环境搭建(此处省去了mysql的步骤) 在azure上搭建上述的开发环境和在本地PC搭建是一样的步骤,具体介绍请参看这里. 2.从外网访问 注意,这一步的前提是 ...
- JS数据模板分离(告别字符串拼接)-template
刚开始在写第一个动态网页的demo时,由于html不多,便使用字符串拼接的方法添加到dom来渲染,可是在后来写某外卖app时也需要如此添加,打开代码一看几千行,突然感觉累觉不爱 一行行的拼接有这功夫别 ...
- centos7安装docker-ce新版
先卸载系统的旧版本yum remove docker \ docker-common \ docker-selinux \ ...
- centos 7.0 查看selinux状态|关闭|开启
Linux在安装好之后通常SELinux都是出于默认开启的状态,开启的情况下会导致一些服务的安装不成功. 在不需要的情况下完全可以关闭掉,下面是在centos 7.0里面如何查看,关闭selinux. ...
- 1968. [AHOI2005]约数研究【数论】
Description Input 只有一行一个整数 N(0 < N < 1000000). Output 只有一行输出,为整数M,即f(1)到f(N)的累加和. Sample Input ...
- Java50道经典习题-程序23 求岁数
题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁.问第4个人岁数,他说比第3个人大2岁.问第三个人,又说比第2人大两岁.问第2个人,说比第1个人大两岁.最后问第一个人,他说是10岁.请问 ...
- 解决Bug步骤
1.看报错.将bug定位到文件.类.方法. 2.打断点.将bug定位到具体代码行号. 3.分析断点输出结果. 4.结合报错和断点结果,修改代码. 总之:拆解问题.定位问题.分析问题.解决问题.