SpringBoot集成ElasticSearch,实现模糊查询,批量CRUD,排序,分页,高亮

news2025/1/11 14:03:15

导入elasticsearch依赖

在pom.xml里加入如下依赖:

<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

非常重要:检查依赖版本是否与你当前所用的版本是否一致,如果不一致,会连接失败!!!!!!!!

# 创建高级客户端


import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class ElasticSearchClientConfig {
    @Bean
    public RestHighLevelClient restHighLevelClient(){
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("服务器IP", 9200, "http")));
        return client;
    }
}

基本用法

1.创建、判断存在、删除索引

import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest;
import org.elasticsearch.action.support.master.AcknowledgedResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.indices.CreateIndexRequest;
import org.elasticsearch.client.indices.CreateIndexResponse;
import org.elasticsearch.client.indices.GetIndexRequest;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.io.IOException;

@SpringBootTest
class ElasticsearchApplicationTests {

  @Autowired
  private RestHighLevelClient restHighLevelClient;

  @Test
  void testCreateIndex() throws IOException {
    //1.创建索引请求
    CreateIndexRequest request = new CreateIndexRequest("ljx666");
    //2.客户端执行请求IndicesClient,执行create方法创建索引,请求后获得响应
    CreateIndexResponse response=
        restHighLevelClient.indices().create(request, RequestOptions.DEFAULT);
    System.out.println(response);
  }

  @Test
  void testExistIndex() throws IOException {
        //1.查询索引请求
    GetIndexRequest request=new GetIndexRequest("ljx666");
        //2.执行exists方法判断是否存在
    boolean exists=restHighLevelClient.indices().exists(request,RequestOptions.DEFAULT);
    System.out.println(exists);
  }

  @Test
  void testDeleteIndex() throws IOException {
        //1.删除索引请求
    DeleteIndexRequest request=new DeleteIndexRequest("ljx666");
        //执行delete方法删除指定索引
    AcknowledgedResponse delete = restHighLevelClient.indices().delete(request, RequestOptions.DEFAULT);
    System.out.println(delete.isAcknowledged());
  }

}

2.对文档的CRUD

创建文档:

注意:如果添加时不指定文档ID,他就会随机生成一个ID,ID唯一。

创建文档时若该ID已存在,发送创建文档请求后会更新文档中的数据。

@Test
void testAddUser() throws IOException {
  //1.创建对象
  User user=new User("Go",21,new String[]{"内卷","吃饭"});
  //2.创建请求
  IndexRequest request=new IndexRequest("ljx666");
  //3.设置规则 PUT /ljx666/_doc/1
  //设置文档id=6,设置超时=1s等,不设置会使用默认的
  //同时支持链式编程如 request.id("6").timeout("1s");
  request.id("6");
  request.timeout("1s");

  //4.将数据放入请求,要将对象转化为json格式
    //XContentType.JSON,告诉它传的数据是JSON类型
  request.source(JSONValue.toJSONString(user), XContentType.JSON);

  //5.客户端发送请求,获取响应结果
  IndexResponse indexResponse=restHighLevelClient.index(request,RequestOptions.DEFAULT);
  System.out.println(indexResponse.toString());
  System.out.println(indexResponse.status());
}

获取文档中的数据:

@Test
void testGetUser() throws IOException {
  //1.创建请求,指定索引、文档id
  GetRequest request=new GetRequest("ljx666","1");
  GetResponse getResponse=restHighLevelClient.get(request,RequestOptions.DEFAULT);

  System.out.println(getResponse);//获取响应结果
  //getResponse.getSource() 返回的是Map集合
  System.out.println(getResponse.getSourceAsString());//获取响应结果source中内容,转化为字符串

}

更新文档数据:

注意:需要将User对象中的属性全部指定值,不然会被设置为空,如User只设置了名称,那么只有名称会被修改成功,其他会被修改为null。

@Test
void testUpdateUser() throws IOException {
  //1.创建请求,指定索引、文档id
  UpdateRequest request=new UpdateRequest("ljx666","6");

  User user =new User("GoGo",21,new String[]{"内卷","吃饭"});
  //将创建的对象放入文档中
  request.doc(JSONValue.toJSONString(user),XContentType.JSON);

  UpdateResponse updateResponse=restHighLevelClient.update(request,RequestOptions.DEFAULT);
  System.out.println(updateResponse.status());//更新成功返回OK
}

删除文档:

@Test
void testDeleteUser() throws IOException {
  //创建删除请求,指定要删除的索引与文档ID
  DeleteRequest request=new DeleteRequest("ljx666","6");

  DeleteResponse updateResponse=restHighLevelClient.delete(request,RequestOptions.DEFAULT);
  System.out.println(updateResponse.status());//删除成功返回OK,没有找到返回NOT_FOUND
}

3.批量CRUD数据

这里只列出了批量插入数据,其他与此类似。

注意:hasFailures()方法是返回是否失败,即它的值为false时说明上传成功。

@Test
void testBulkAddUser() throws IOException {
  BulkRequest bulkRequest=new BulkRequest();
  //设置超时
  bulkRequest.timeout("10s");

  ArrayList<User> list=new ArrayList<>();
  list.add(new User("Java",25,new String[]{"内卷"}));
  list.add(new User("Go",18,new String[]{"内卷"}));
  list.add(new User("C",30,new String[]{"内卷"}));
  list.add(new User("C++",26,new String[]{"内卷"}));
  list.add(new User("Python",20,new String[]{"内卷"}));

  int id=1;
  //批量处理请求
  for (User u :list){
    //不设置id会生成随机id
    bulkRequest.add(new IndexRequest("ljx666")
        .id(""+(id++))
        .source(JSONValue.toJSONString(u),XContentType.JSON));
  }

  BulkResponse bulkResponse=restHighLevelClient.bulk(bulkRequest,RequestOptions.DEFAULT);
  System.out.println(bulkResponse.hasFailures());//是否执行失败,false为执行成功
}

4.查询所有、模糊查询、分页查询、排序、高亮显示

@Test
void testSearch() throws IOException {
  SearchRequest searchRequest=new SearchRequest("ljx666");//里面可以放多个索引
  SearchSourceBuilder sourceBuilder=new SearchSourceBuilder();//构造搜索条件

  //此处可以使用QueryBuilders工具类中的方法
  //1.查询所有
  sourceBuilder.query(QueryBuilders.matchAllQuery());
  //2.查询name中含有Java的
  sourceBuilder.query(QueryBuilders.multiMatchQuery("java","name"));
  //3.分页查询
  sourceBuilder.from(0).size(5);

  //4.按照score正序排列
  //sourceBuilder.sort(SortBuilders.scoreSort().order(SortOrder.ASC));
  //5.按照id倒序排列(score会失效返回NaN)
  //sourceBuilder.sort(SortBuilders.fieldSort("_id").order(SortOrder.DESC));

  //6.给指定字段加上指定高亮样式
  HighlightBuilder highlightBuilder=new HighlightBuilder();
  highlightBuilder.field("name").preTags("<span style='color:red;'>").postTags("</span>");
  sourceBuilder.highlighter(highlightBuilder);

  searchRequest.source(sourceBuilder);
  SearchResponse searchResponse=restHighLevelClient.search(searchRequest,RequestOptions.DEFAULT);

  //获取总条数
  System.out.println(searchResponse.getHits().getTotalHits().value);
  //输出结果数据(如果不设置返回条数,大于10条默认只返回10条)
  SearchHit[] hits=searchResponse.getHits().getHits();
  for(SearchHit hit :hits){
    System.out.println("分数:"+hit.getScore());
    Map<String,Object> source=hit.getSourceAsMap();
    System.out.println("index->"+hit.getIndex());
    System.out.println("id->"+hit.getId());
    for(Map.Entry<String,Object> s:source.entrySet()){
      System.out.println(s.getKey()+"--"+s.getValue());
    }
  }
}

总结

1.大致流程

创建对应的请求 --> 设置请求(添加规则,添加数据等) --> 执行对应的方法(传入请求,默认请求选项)–> 接收响应结果(执行方法返回值)–> 输出响应结果中需要的数据(source,status等)

2.注意事项

  • 如果不指定id,会自动生成一个随机id

  • 正常情况下,不应该这样使用new IndexRequest(“ljx777”),如果索引发生改变了,那么代码都需要修改,可以定义一个枚举类或者一个专门存放常量的类,将变量用final static等进行修饰,并指定索引值。其他地方引用该常量即可,需要修改也只需修改该类即可。

  • elasticsearch相关的东西,版本都必须一致,不然会报错

  • elasticsearch很消耗内存,建议在内存较大的服务器上运行elasticsearch,否则会因为内存不足导致elasticsearch自动killed

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/385029.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

邮件发送,正文内容格式h5,模板字符串拼接使用及赋值,原生js

一、邮件发送 需求不难&#xff0c;传指定的参数给后端&#xff0c;调接口就直接发送了 就是参数里有个正文部分&#xff0c;一定要用h5写 写vue写习惯了&#xff0c;原生的都快忘光了&#xff0c;走了些弯路 二、h5 在页面上有个邮件发送的按钮&#xff0c;点击按钮打开弹窗…

10分钟搞定win11安卓子系统

10分钟搞定win11安卓子系统Android子系统的要求一、安装 Windows 虚拟化支持二、Win11 正式版安装安卓子系统方法教程 (离线包安装)三、在Win11 安卓子系统安装 APK 软件包教程Windows 11 WSA 安装 APK 方法&#xff1a;Windows 11上成功运行安卓APP安装国内的 Android 应用商店…

windows系统无法保存文件的解决方案

❤关注我&#xff0c;不迷路❤ 点击进入PC常见故障汇总专栏 近期收到部分反馈&#xff0c;在windows的电脑上保存一个文件的时候&#xff08;另存为&#xff09;&#xff0c;选择完目标文件夹后无法保存&#xff0c;点击系统的保存按钮&#xff08;有些系统展示为打开按钮&…

2023最新谷粒商城笔记之订单服务篇(全文总共13万字,超详细)

订单服务 页面环境搭建 配置动静环境 在服务器的mydata/nginx/html/static 路径下创建一个 order 文件夹&#xff0c;在order路径下分别创建以下几个文件夹&#xff0c;用来存放对应的静态资源 detail 文件夹下存放 等待付款的静态资源&#xff0c; 并将等待付款文件夹下的页…

DC-4 靶场学习

信息搜集&#xff1a; 首先获取靶场ip&#xff0c;和之前一样。 arp-scan -l nmap -sP 192.168.28.0/24然后访问。 发现需要登录。 漏洞分析: 直接用bp爆破&#xff0c;爆破出来密码为happy&#xff0c;登录。 发现执行了命令&#xff0c;抓包。 修改命令可以执行&#xff…

客户案例|FPGA研发管理解决方案:UniPro瀑布+敏捷 打造高效能组织

2023开年以来&#xff0c;新享科技项目管理软件UniPro收获一波客户侧的点赞好评。在过去一年中&#xff0c;UniPro不断与客户保持高频沟通&#xff0c;满足客户需求为出发点&#xff0c;以产品功能实现为落脚点&#xff0c;不断打磨产品。 以UniPro客户京微齐力为例&#xff0…

Vulnhub靶场----9、DC-9

文章目录一、环境搭建二、渗透流程三、思路总结一、环境搭建 DC-9下载地址&#xff1a;https://download.vulnhub.com/dc/DC-9.zip kali&#xff1a;192.168.144.148 DC-9&#xff1a;192.168.144.158 二、渗透流程 1、信息收集nmap -T5 -A -p- -sV -sT 192.168.144.158思路&am…

IDEA Android 网格布局(GridLayout)示例(计算器界面布局)

网格布局(GridLayout&#xff09; 示例程序效果&#xff08;实现类似vivo手机自带计算器UI&#xff09; 真机和模拟器运行效果&#xff1a; 简述&#xff1a; GridLayout(网格布局)和TableLayout&#xff08;表格布局&#xff09;有类似的地方&#xff0c;通俗来讲可以理解为…

搜广推 Product-based Neural Networks (PNN) - 改进特征交叉的方式

😄 PNN:2016年上海交通大学提出。 文章目录 1、PNN1.1、原理1.2、创新点:product层1.3、product层z部分的输出:l~z~ 的计算方式:1.4、product层z部分的输出:l~p~ 的计算方式:1.4.1、IPNN1.4.2、OPNN1.5、优点1.6、缺点Reference1、PNN PNN:Product-based Neural Netwo…

Spark 故障排除

1 故障排除一&#xff1a;控制reduce端缓冲大小以避免OOM 在Shuffle过程&#xff0c;reduce端task并不是等到map端task将其数据全部写入磁盘后再去拉取&#xff0c;而是map端写一点数据&#xff0c;reduce端task就会拉取一小部分数据&#xff0c;然后立即进行后面的聚合、算子…

colletions学习和链式调用,以及优雅的展示代码

1&#xff0c;python 中尽量减少缩进可以直接 if code ! 1: return {msg:2003} 继续写下面的逻辑 2&#xff0c;关于&#xff08;1&#xff09;&#xff0c;&#xff08;1&#xff0c;&#xff09;区别 &#xff08;1&#xff09;表示直接计算运行 &#xff08;1*2*345&a…

Leetcode.2359 找到离给定两个节点最近的节点

题目链接 Leetcode.2359 找到离给定两个节点最近的节点 Rating &#xff1a; 1715 题目描述 给你一个 n个节点的 有向图 &#xff0c;节点编号为 0到 n - 1&#xff0c;每个节点 至多 有一条出边。 有向图用大小为 n下标从 0开始的数组 edges表示&#xff0c;表示节点 i有一条…

数字档案室测评的些许感悟

我是甲方&#xff0c;明明我家是档案“室”&#xff0c;为什么申请的是数字档案“馆”&#xff1f; 笔者正对着手里的一份方案苦笑&#xff0c;甲方爸爸是某机关单位档案室&#xff0c;方案最后的附件赫然写着几个大字&#xff1a;“申请国家级数字档案馆……“。这样的事屡见…

SpringMVC再学习

基于原生的Servlet&#xff0c;通过了功能强大的前端控制器DispatcherServlet&#xff0c;对请求和相应进行统一处理 如今我们不再去web.xml中去主持servlet 而是直接创建一个配置类ServletContainersInitConfig去基础AbstractDispatcherServletInitializer createServletApp…

高性能 WPF 图表控件LightningChart.NET:支持从 Web 服务器获取数据 | 附最新版试用下载

LightningChart.NET 是一款高性能 WPF 和 Winforms 图表,可以实时可视化多达1万亿个数据点。可有效利用CPU和内存资源&#xff0c;实时监控数据流。同时&#xff0c;LightningChart使用突破性创新技术&#xff0c;以实时优化为前提&#xff0c;大大提升了实时渲染的效率和效果&…

Python的面向对象,详细讲解Python之用处等基本常识

目录 Python 面向对象 面向对象技术简介 创建类 实例 实例 self代表类的实例&#xff0c;而非类 实例 创建实例对象 访问属性 实例 Python内置类属性 实例 python对象销毁(垃圾回收) 实例 实例 类的继承 实例 方法重写 实例 基础重载方法 运算符重载 实例…

机器学习: 可视化反卷积操作

转置卷积操作的详细分解 1. 简介 转置卷积是用于生成图像的&#xff0c;尽管它们已经存在了一段时间&#xff0c;并且得到了很好的解释——我仍然很难理解它们究竟是如何完成工作的。我分享的文章[1]描述了一个简单的实验来说明这个过程。我还介绍了一些有助于提高网络性能的技…

yolov5的基本配置

yolov5的基本配置train.pydata.yaml数据集标签文件格式:总结train.py def parse_opt(knownFalse):parser argparse.ArgumentParser()parser.add_argument(--weights, typestr, defaultROOT / yolov5s.pt, helpinitial weights path)parser.add_argument(--cfg, typestr, defau…

【Java面试篇】Spring中@Transactional注解事务失效的常见场景

文章目录Transactional注解的失效场景☁️前言&#x1f340;前置知识&#x1f341;场景一&#xff1a;Transactional应用在非 public 修饰的方法上&#x1f341;场景二&#xff1a; propagation 属性设置错误&#x1f341;场景三&#xff1a;rollbackFor属性设置错误&#x1f3…

Apache druid未授权命令执行漏洞复现

简介 Apache Druid是一个实时分析型数据库&#xff0c;旨在对大型数据集进行快速的查询分析&#xff08;"OLAP"查询)。Druid最常被当做数据库来用以支持实时摄取、高性能查询和高稳定运行的应用场景&#xff0c;同时&#xff0c;Druid也通常被用来助力分析型应用的图…