ElasticSearch Java API详解 Spring

1.spring已集成了elasticSearch的搜索API

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
    <version>3.2.0.RELEASE</version>
</dependency>

 

2.yml文件中配置ES库的地址和密码

spring:
  data:
    elasticsearch:
      cluster-name: elasticsearch
      cluster-nodes: 172.16.17.230:9300
      repositories:
        enabled: true

 

3.在es-service可以直接注入使用:

@Resource
private ElasticsearchTemplate elasticsearchTemplate;

4.查询参数准备:

SearchQuery query; 用于封装查询条件
Class<T> clazz; 用于接收查询结果的实体对象

5.执行查询:

AggregatedPage<T> ts = elasticsearchTemplate.queryForPage(query, clazz); //分页查询 会返回总记录数
List<T> tList = elasticsearchTemplate.queryForList(query, clazz); //不分页查询 返回结果列表

 

重点一:query参数的拼装 以SearchQuery的实现类NativeSearchQuery为例:

SearchQuery query = new NativeSearchQueryBuilder()
                       .withQuery(
                            QueryBuilders.boolQuery() //声明要一个布尔类型的结果 类似where
                           //must相当于and ,matchQuery代表参数分词后进行筛选 
                           .must(QueryBuilders.matchQuery(fieldName,fieldValue))

// matchPhraseQuery 支持一个搜索参数匹配多个字段

                           .must(QueryBuilders.matchPhraseQuery(keyword, keywordFields));

// should相当于or ,termQuery代表参数不分词进行筛选 fieldValue可以传数组(termsQuery),代替SQL中的 in

                           .should(QueryBuilders.termQuery(fieldName,fieldValue))
                          )
                       .withPageable(PageRequest.of(pageNum, pageSize)) //分页配置

.build();

Class<T> clazz = TestClass.class;

实体类想要接收ES的查询结果,需要配置注解

在实体类上加上 :@org.springframework.data.elasticsearch.annotations.Document(indexName = "indexName", type = "_doc")

如果ES的mapping字段名与实体类属性名不一致,可在实体类属性上加@JsonProperty("ES mapping 字段名") 设置别名。


重点二:termQuery 和 matchQuery

termQuery : 精确查询,直接拿查询条件去匹配

matchQuery:分词查询,将查询条件进行分词,然后拿分词后的结果去匹配。

 

重点三:精准匹配时用数字分词机制

当库中的数据有汉字或者查询条件是汉字时,ES会对汉字进行分词,容易造成查询结果不够精确。

而连续的数字字符串会被当成一个词,不会被细分更小单元。

举例说明:

ES数据: tag_name : "王者荣耀 活动"

查询关键字:王者荣耀

此时是无法匹配到ES中的数据的,而查询 “王者” 或者 查询 “荣耀” 可以匹配到(查询结果不精准)。

解决办法:将标签中存储的标签转化成数字id,ES的数据变成了 tag_name: "411 25"

查询条件 : 411

此时可以匹配到ES的数据。

使用连续英文也可以。

 

 

1.spring已集成了elasticSearch的搜索API

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
    <version>3.2.0.RELEASE</version>
</dependency>

 

2.yml文件中配置ES库的地址和密码

spring:
  data:
    elasticsearch:
      cluster-name: elasticsearch
      cluster-nodes: 172.16.17.230:9300
      repositories:
        enabled: true

 

3.在es-service可以直接注入使用:

@Resource
private ElasticsearchTemplate elasticsearchTemplate;

4.查询参数准备:

SearchQuery query; 用于封装查询条件
Class<T> clazz; 用于接收查询结果的实体对象

5.执行查询:

AggregatedPage<T> ts = elasticsearchTemplate.queryForPage(query, clazz); //分页查询 会返回总记录数
List<T> tList = elasticsearchTemplate.queryForList(query, clazz); //不分页查询 返回结果列表

 

重点一:query参数的拼装 以SearchQuery的实现类NativeSearchQuery为例:

SearchQuery query = new NativeSearchQueryBuilder()
                       .withQuery(
                            QueryBuilders.boolQuery() //声明要一个布尔类型的结果 类似where
                           //must相当于and ,matchQuery代表参数分词后进行筛选 
                           .must(QueryBuilders.matchQuery(fieldName,fieldValue))

// matchPhraseQuery 支持一个搜索参数匹配多个字段

                           .must(QueryBuilders.matchPhraseQuery(keyword, keywordFields));

// should相当于or ,termQuery代表参数不分词进行筛选 fieldValue可以传数组(termsQuery),代替SQL中的 in

                           .should(QueryBuilders.termQuery(fieldName,fieldValue))
                          )
                       .withPageable(PageRequest.of(pageNum, pageSize)) //分页配置

.build();

Class<T> clazz = TestClass.class;

实体类想要接收ES的查询结果,需要配置注解

在实体类上加上 :@org.springframework.data.elasticsearch.annotations.Document(indexName = "indexName", type = "_doc")

如果ES的mapping字段名与实体类属性名不一致,可在实体类属性上加@JsonProperty("ES mapping 字段名") 设置别名。


重点二:termQuery 和 matchQuery

termQuery : 精确查询,直接拿查询条件去匹配

matchQuery:分词查询,将查询条件进行分词,然后拿分词后的结果去匹配。

 

重点三:精准匹配时用数字分词机制

当库中的数据有汉字或者查询条件是汉字时,ES会对汉字进行分词,容易造成查询结果不够精确。

而连续的数字字符串会被当成一个词,不会被细分更小单元。

举例说明:

ES数据: tag_name : "王者荣耀 活动"

查询关键字:王者荣耀

此时是无法匹配到ES中的数据的,而查询 “王者” 或者 查询 “荣耀” 可以匹配到(查询结果不精准)。

解决办法:将标签中存储的标签转化成数字id,ES的数据变成了 tag_name: "411 25"

查询条件 : 411

此时可以匹配到ES的数据。

使用连续英文也可以。

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值