当前位置:首页 > 科技  > 软件

Java中通过Elasticsearch实现全局检索功能的方法和步骤及源代码

来源: 责编: 时间:2023-12-08 09:15:42 351观看
导读以下是通过Java Client API使用Elasticsearch实现全局检索功能的方法和步骤:一、添加Elasticsearch Java客户端依赖首先需要在项目中添加Elasticsearch Java客户端的依赖。从Maven仓库中获取Elasticsearch Java客户端

DzE28资讯网——每日最新资讯28at.com

以下是通过Java Client API使用Elasticsearch实现全局检索功能的方法和步骤:DzE28资讯网——每日最新资讯28at.com

一、添加Elasticsearch Java客户端依赖

首先需要在项目中添加Elasticsearch Java客户端的依赖。从Maven仓库中获取Elasticsearch Java客户端的依赖项,将以下代码添加到pom.xml文件中:DzE28资讯网——每日最新资讯28at.com

<dependencies>    <dependency>        <groupId>org.elasticsearch.client</groupId>        <artifactId>elasticsearch-rest-high-level-client</artifactId>        <version>{version}</version>    </dependency></dependencies>

其中{version}是Elasticsearch Java客户端版本号,可以在Elasticsearch官方网站上找到最新版本。DzE28资讯网——每日最新资讯28at.com

二、连接Elasticsearch

在Java程序中连接Elasticsearch需要使用RestHighLevelClient,下面是一个简单的示例:DzE28资讯网——每日最新资讯28at.com

RestHighLevelClient client = new RestHighLevelClient(        RestClient.builder(new HttpHost("localhost", 9200, "http")));

在上面的代码中,我们创建了一个RestHighLevelClient实例,用于连接名称为localhost的Elasticsearch节点,端口号为9200。如果您需要连接其他Elasticsearch节点,可以修改host和port参数。DzE28资讯网——每日最新资讯28at.com

三、创建索引

在使用Elasticsearch进行全局检索之前,需要先创建一个索引。下面是一个简单的示例:DzE28资讯网——每日最新资讯28at.com

CreateIndexRequest request = new CreateIndexRequest("my_index");client.indices().create(request, RequestOptions.DEFAULT);

在上面的代码中,我们创建了一个名为my_index的索引。如果该索引已经存在,将不执行任何操作。如果需要创建多个索引,可以重复使用上述代码创建其他索引。DzE28资讯网——每日最新资讯28at.com

四、添加文档

在创建索引之后,需要向该索引中添加一些文档,以便进行全局检索。下面是一个简单的示例:DzE28资讯网——每日最新资讯28at.com

IndexRequest request = new IndexRequest("my_index");String jsonString = "{" +        "/"user/":/"John/"," +        "/"message/":/"hello/"" +        "}";request.source(jsonString, XContentType.JSON);IndexResponse response = client.index(request, RequestOptions.DEFAULT);

在上面的代码中,我们向名为my_index的索引中添加了一个文档,该文档包含user和message两个字段。如果您需要添加多个文档,可以重复使用上述代码添加其他文档。DzE28资讯网——每日最新资讯28at.com

五、执行全局检索

在添加一些文档之后,可以执行全局检索来查找与给定条件匹配的所有文档。下面是一个简单的示例:DzE28资讯网——每日最新资讯28at.com

SearchRequest searchRequest = new SearchRequest("my_index"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchQuery("message", "hello")); searchRequest.source(searchSourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);

在上面的代码中,我们执行了一个全局检索操作,以查找my_index索引中message字段中包含"hello"的所有文档。使用SearchRequest和SearchSourceBuilder类来指定检索条件和索引名称。在检索完成后,可以从SearchResponse对象中获取匹配的文档列表。DzE28资讯网——每日最新资讯28at.com

六、处理结果并展示

我们需要处理检索结果,并将结果显示给用户。以下是一个简单的示例,它将搜索结果中的每个文档的message字段提取出来,并显示给用户:DzE28资讯网——每日最新资讯28at.com

SearchHits hits = searchResponse.getHits();for (SearchHit hit : hits) {    String sourceAsString = hit.getSourceAsString();    Map<String, Object> sourceAsMap = hit.getSourceAsMap();    String message = sourceAsMap.get("message").toString();    System.out.println(message);}

在上面的代码中,我们首先获取到SearchHits对象,然后遍历每个SearchHit,将每个文档的message字段提取出来并显示。可以将上述代码嵌入到你的应用程序的检索结果处理逻辑中,以向用户展示搜索结果。DzE28资讯网——每日最新资讯28at.com

七、关闭Elasticsearch连接

当你的程序完成Elasticsearch的全局检索操作后,需要关闭与Elasticsearch的连接,以下是一个简单的示例:DzE28资讯网——每日最新资讯28at.com

client.close();

在上面的代码中,我们关闭了与Elasticsearch的连接。在使用任何资源后,都应关闭以避免资源泄漏。DzE28资讯网——每日最新资讯28at.com

通过以上几个步骤,我们可以通过Java程序使用Elasticsearch进行全局检索。需要注意的是,Elasticsearch有很多强大的功能,例如排序、分页、聚合等,可以更复杂的搜索需求。你可以参考Elasticsearch官方文档,了解更多关于Elasticsearch的使用。DzE28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-39532-0.htmlJava中通过Elasticsearch实现全局检索功能的方法和步骤及源代码

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 下一个项目,建议使用这七个 JavaScript 库

下一篇: IntelliJ IDEA 2023.3 版本更新发布:商洽接入阿里云通义大模型,为中国开发者带来 AI 辅助编程

标签:
  • 热门焦点
  • 直屏旗舰来了 iQOO 12和K70 Pro同台竞技

    旗舰机基本上使用的都是双曲面屏幕,这就让很多喜欢直屏的爱好者在苦等一款直屏旗舰,这次,你们等到了。据博主数码闲聊站带来的最新爆料称,Redmi下代旗舰K70 Pro和iQOO 12两款手
  • 不容错过的MSBuild技巧,必备用法详解和实践指南

    一、MSBuild简介MSBuild是一种基于XML的构建引擎,用于在.NET Framework和.NET Core应用程序中自动化构建过程。它是Visual Studio的构建引擎,可在命令行或其他构建工具中使用
  • 企业采用CRM系统的11个好处

    客户关系管理(CRM)软件可以为企业提供很多的好处,从客户保留到提高生产力。  CRM软件用于企业收集客户互动,以改善客户体验和满意度。  CRM软件市场规模如今超过580
  • 十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • .NET 程序的 GDI 句柄泄露的再反思

    一、背景1. 讲故事上个月我写过一篇 如何洞察 C# 程序的 GDI 句柄泄露 文章,当时用的是 GDIView + WinDbg 把问题搞定,前者用来定位泄露资源,后者用来定位泄露代码,后面有朋友反
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 超闭合精工铰链 彻底消灭缝隙 三星Galaxy Z Flip5与Galaxy Z Fold5发布

    2023年7月26日,三星电子正式发布了Galaxy Z Flip5与Galaxy Z Fold5。三星新一代折叠屏手机采用超闭合精工铰链,让折叠后的缝隙不再可见。同时,配合处
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
Top