SpringBoot整合新版本Elasticsearch4.2.x

概述

最近重新看了下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());
介于API太多,剩下的项目中碰到实际需求再看…
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值