当前位置: 首页 > news >正文

Elasticsearch RESTful API入门:全文搜索实战(Java版)

Elasticsearch RESTful API入门:全文搜索实战(Java版)

本文结合Java客户端API,深入讲解Elasticsearch全文搜索的实现。包含10+个实战示例及对应的Java代码,涵盖match、multi_match、高亮显示等核心功能。

一、环境准备

1. 添加Maven依赖

<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId><version>7.17.0</version> <!-- 请匹配ES服务器版本 -->
</dependency>

2. 初始化客户端

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

3. 创建索引(Java实现)

CreateIndexRequest request = new CreateIndexRequest("books");
request.settings(Settings.builder().put("index.number_of_shards", 1).put("index.number_of_replicas", 1)
);
// 定义mapping
XContentBuilder mappingBuilder = XContentFactory.jsonBuilder().startObject().startObject("properties").startObject("title").field("type", "text").field("analyzer", "ik_max_word").endObject().startObject("author").field("type", "keyword").endObject().startObject("content").field("type", "text").field("analyzer", "ik_smart").endObject().startObject("publish_date").field("type", "date").endObject().startObject("rating").field("type", "float").endObject().endObject().endObject();
request.mapping(mappingBuilder);
CreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT);

二、基础全文搜索实战(Java API)

1. match查询

SearchRequest searchRequest = new SearchRequest("books");
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(QueryBuilders.matchQuery("content", "搜索技术"));
searchRequest.source(sourceBuilder);
SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
// 处理结果...

2. 设置AND逻辑

MatchQueryBuilder matchQuery = QueryBuilders.matchQuery("content", "分布式存储").operator(Operator.AND);
sourceBuilder.query(matchQuery);

3. 多字段搜索(multi_match)

MultiMatchQueryBuilder multiMatchQuery = QueryBuilders.multiMatchQuery("性能优化", "title", "content");
sourceBuilder.query(multiMatchQuery);

三、高级搜索技巧(Java实现)

1. 短语搜索

MatchPhraseQueryBuilder phraseQuery = QueryBuilders.matchPhraseQuery("content", "典型应用").slop(2); // 允许间隔2个词
sourceBuilder.query(phraseQuery);

2. 模糊搜索

MatchQueryBuilder fuzzyQuery = QueryBuilders.matchQuery("title", "Elasticsarch").fuzziness(Fuzziness.AUTO);
sourceBuilder.query(fuzzyQuery);

四、搜索结果优化(Java API)

1. 高亮显示

HighlightBuilder highlightBuilder = new HighlightBuilder();
highlightBuilder.field("content").preTags("<strong>").postTags("</strong>");
sourceBuilder.highlighter(highlightBuilder);
// 解析高亮结果
SearchHits hits = response.getHits();
for (SearchHit hit : hits) {Map<String, HighlightField> highlightFields = hit.getHighlightFields();HighlightField highlight = highlightFields.get("content");if (highlight != null) {Text[] fragments = highlight.fragments();String fragmentString = fragments[0].string();System.out.println(fragmentString);}
}

2. 结果排序

sourceBuilder.sort(new ScoreSortBuilder().order(SortOrder.DESC));
sourceBuilder.sort(new FieldSortBuilder("rating").order(SortOrder.DESC));

3. 字段权重

MultiMatchQueryBuilder weightedQuery = QueryBuilders.multiMatchQuery("搜索算法").field("title", 3.0f) // 提升title权重.field("content");
sourceBuilder.query(weightedQuery);

五、复杂场景实战(Java)

1. 组合搜索(bool查询)

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("content", "技术")).should(QueryBuilders.matchPhraseQuery("title", "实战")).filter(QueryBuilders.rangeQuery("rating").gte(4.0));
sourceBuilder.query(boolQuery);

2. 搜索建议

SuggestionBuilder termSuggestionBuilder = SuggestBuilders.termSuggestion("title").text("elastc").suggestMode(TermSuggestionBuilder.SuggestMode.ALWAYS);
SuggestBuilder suggestBuilder = new SuggestBuilder();
suggestBuilder.addSuggestion("title_suggest", termSuggestionBuilder);
sourceBuilder.suggest(suggestBuilder);
// 解析建议结果
Suggest suggest = response.getSuggest();
TermSuggestion termSuggestion = suggest.getSuggestion("title_suggest");
for (TermSuggestion.Entry entry : termSuggestion.getEntries()) {for (TermSuggestion.Entry.Option option : entry) {System.out.println(option.getText().string());}
}

六、资源释放

client.close(); // 使用后关闭客户端

七、常见问题(Java客户端相关)

  1. 依赖冲突
    确保Elasticsearch客户端版本与服务器一致
  2. 连接池管理
    推荐单例模式创建客户端,避免频繁创建销毁
  3. 异步操作
    高性能场景可使用异步客户端:
    client.searchAsync(searchRequest, RequestOptions.DEFAULT, new ActionListener<>() {@Overridepublic void onResponse(SearchResponse response) { /*处理响应*/ }@Overridepublic void onFailure(Exception e) { /*处理异常*/ }
    });
    

提示:完整代码示例可在GitHub仓库获取(虚拟链接:https://github.com/example/es-java-demo)

RESTful 操作Java 类/方法
创建索引CreateIndexRequest, RestHighLevelClient#indices().create()
添加文档IndexRequest
match查询QueryBuilders.matchQuery()
bool查询BoolQueryBuilder
高亮显示HighlightBuilder
分页SearchSourceBuilder#from()size()
排序SortBuilders

下集预告:《Elasticsearch 高可用实战:架构设计与场景化解决方案》

http://www.dtcms.com/a/271076.html

相关文章:

  • 【Oracle报错】[INS-13001] 环境不满足最低要求。
  • 以太网基础④IP 协议介绍与 IP 校验和算法实现
  • 逆向 qq 音乐 sign,data, 解密 response 返回的 arraybuffer
  • 在 Coze 平台工作流开发中,使用图生视频大模型需要时间比较长比如5分钟,如何解决工作流运行超时的问题以及等在视频生成以后再向下走
  • JavaEE初阶第八期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(六)
  • Jmeter进阶篇(35)完美解决Jmeter转换HTML报告报错“Begin size 0 is not equal to fixed size 5”
  • git中的指令解释
  • 详解CAN总线的位填充机制
  • 【学习笔记】计算机操作系统(七)—— 文件管理
  • 全志H616开发学习文档
  • prometheus+grafana接入kafka实战
  • Python管理咨询数据可视化实战:收入分布与顾问利用率双轴对比图表生成脚本
  • 基于BRPC构建高性能HTTP/2服务实战指南
  • python之requests库解析
  • 1️⃣理解大语言模型
  • 【时时三省】(C语言基础)通过指针引用数组
  • 阿里开源WebSailor:超越闭源模型的网络智能体新星
  • 疏锦行Python打卡 DAY 54 Inception网络及其思考
  • HTML + CSS + JavaScript
  • 字体 Unicode 区块字符展示 PDF 生成器
  • Ubuntu重装系统后ssh连接不上(遇到 ​​“Unit ssh.service not found“​​ 错误)
  • kubernetes存储入门
  • Spring Boot + Vue.js 全栈开发:从前后端分离到高效部署,打造你的MVP利器!
  • 【05】MFC入门到精通——MFC 为对话框中的控件添加变量 和 数据交换和检验
  • 【01】MFC入门到精通—— MFC新建基于对话框的项目 介绍(工作界面、资源视图 、类视图)
  • Flink-1.19.0源码详解6-JobGraph生成-后篇
  • AJAX总结
  • Flink1.20.1集成Paimon遇到的问题
  • Electron 应用打包全指南
  • 机器学习模型在C++平台的部署