SpringBoot整合新版本Elasticsearch
概述
最近重新看了下ES以及Spring Data Es 的东西,发现变动不小,而且网上东西大多抄来抄去,都是以前的API,新版本变动较大;谨以本文列出基本使用,由于API众多,只能是抛砖引玉。
整合SpringBoot
环境
- es版本:7.16.3
- SpringBoot:2.5.8
- Spring Data ES:4.2.7
Spring Data ES 4.2.7 使用的客户端版本是 7.12.1,本来还想说与ES版本统一一致的,经过测试,不统一也没问题
yaml配置
原来在data下面的除了响应式API相关的配置基本已弃用
spring:
elasticsearch:
rest:
uris: localhost:9200
connection-timeout: 30s
read-timeout: 30s
sniffer:
interval: 5m
delay-after-failure: 1m
测试
Spring Data 下整合的各类数据库,基本都提供了 基于 Repository 和 Operation 两种操作方式。
对于ES而言就是
具体使用哪个,看个人习惯。
本人更倾向于使用 xxxxTemplate
配置实体类(非必须,配置了使用更方便)
@Document(indexName = "person")
@Data
public class Person {
@Id
private Long id;
@Field(type = FieldType.Text, analyzer = "ik_max_word", searchAnalyzer = "ik_max_word")
private String name;
@Field(name = "age2", type = FieldType.Integer)
private Integer age;;
}
注意@Id推荐配置上;如果不配置,ES会随机生成一个字符串;
@Field 用于配置字段属性,如果es要重新定义es中的字段名可用name属性重写,type默认是AUTO,整数影响不会特别大,如果是字符串或者浮点数还是要指定的,字符串中有 text和keyword,浮点中有双精度。
使用 ElasticsearchRestTemplate 与ES交互
- 创建索引
boolean b = elasticsearchRestTemplate.indexOps(Person.class)
.create();
- 校验索引是否存在
elasticsearchRestTemplate.indexOps(Person.class).exists()
- 向索引中添加记录
Person person = new Person();
person.setId(3L);
person.setAge(17);
person.setName("李四");
Person save = elasticsearchRestTemplate.save(person);
- 按id删除记录
elasticsearchRestTemplate.delete("2", Person.class)
- 删除索引
elasticsearchRestTemplate.indexOps(Person.class).delete()
- 按id查询记录
elasticsearchRestTemplate.get("2", Person.class)
- 按条件查询
Query query = new CriteriaQuery(
Criteria.where("name").matches("三丰")
);
SearchHits<Person> searchHits = elasticsearchRestTemplate.search(query, Person.class);
System.out.println(searchHits.getSearchHits());
- 给指定字段加上高亮
Query query = new CriteriaQuery(
Criteria.where("name").matches("三丰")
);
HighlightBuilder builder = new HighlightBuilder();
builder.field("name").preTags("<a class='test'>").postTags("</a>");
query.setHighlightQuery(new HighlightQuery(builder));
SearchHits<Person> searchHits = elasticsearchRestTemplate.search(query, Person.class);
System.out.println(searchHits.getSearchHits());
- 分页查询
Query query = new CriteriaQuery(
Criteria.where("name").matches("三丰")
);
query.setPageable(PageRequest.of(0, 2));
SearchHits<Person> searchHits = elasticsearchRestTemplate.search(query, Person.class);
System.out.println(searchHits.getSearchHits());