ElasticSearch JavaRestClient查询之快速入门

文章目录

      • 查询操作流程概述
      • 构建并发起请求
          • 1. 创建请求对象
          • 2. 设置请求体
          • 3. 发送请求
      • 查询结果的解析
          • 1. 解析结果结构
          • 2. 获取总条数
          • 3. 获取命中的数据
      • 完整示例代码
      • 总结

查询操作流程概述

Elasticsearch 查询操作大致可以分为两个部分:

  1. 构建并发起请求:这一步主要包括构建请求对象和设置查询参数。
  2. 解析查询结果:获取到查询结果后,如何从中提取出我们关心的数据。



构建并发起请求

在 Java 中,查询操作的核心步骤是构建请求对象并配置相关的查询参数,然后通过发送请求来获取结果。

1. 创建请求对象

在使用 Java Rest Client 查询 Elasticsearch 时,首先需要创建一个 SearchRequest 对象。该对象对应着我们发送请求时的路径和查询条件。

  • SearchRequest 对象用于表示搜索请求。
  • 在创建该对象时,我们需要指定索引库名,因为查询请求是基于特定索引库进行的。
// 1.创建request对象
SearchRequest request = new SearchRequest("items");

2. 设置请求体

接下来,我们需要构建请求体,即指定查询条件。请求体通常是一个 JSON 格式的数据,在 Java 中通过 request.source() 来构建。

  • request.source() 代表整个请求体,包含查询条件(query)、分页条件(from/size)、排序条件(sort)、高亮显示(highlight)等。

  • 通过 query 设置查询条件,比如 query(QueryBuiliders.matchAllQuery()) 方法。

例如,通过 QueryBuilders.matchAllQuery() 来构建一个 match all 查询。

// 2.配置request参数
request.source()
        .query(QueryBuilders.matchAllQuery());

3. 发送请求

构建完成请求对象和请求体后,我们就可以使用客户端进行请求的发送。

  • 发送请求的方法是:client.search(searchRequest, RequestOptions.DEFAULT),返回的是查询结果。
// 3.发送请求
SearchResponse response = client.search(request, RequestOptions.DEFAULT);

返回结果:



查询结果的解析

查询结果返回的格式是一个 JSON 对象,通常包含多个层次的信息。为了从中提取所需的数据,我们需要逐层解析。



1. 解析结果结构

查询结果中包含的主要信息有:

  • took:查询消耗的时间
  • hits:查询结果的具体内容

我们要从返回的 SearchResponse 对象中获取 hits 部分,即命中的数据。

// 4.解析结果
SearchHits searchHits = response.getHits();

2. 获取总条数

查询结果中的 total 字段表示总命中的文档数。通过 hits.total().value 可以获取到总条数。

// 4.1.总条数
long total = searchHits.getTotalHits().value;

3. 获取命中的数据

查询的结果存储在 hits 数组中,每个元素都是一个命中的文档。我们通过遍历该数组来提取每一条命中的数据。

// 4.2.命中的数据
    SearchHit[] hits = searchHits.getHits();
    for (SearchHit hit : hits) {
        // 4.2.1.获取source结果
        String json = hit.getSourceAsString();
        // 4.2.2.转为ItemDoc
        ItemDoc doc = JSONUtil.toBean(json, ItemDoc.class);
        
        System.out.println("doc = " + doc);

每个 SearchHit 对象都包含一个 source 字段,它是该文档的原始 JSON 数据。我们可以将其转换为 Java 对象(如 ItemDoc)。



完整示例代码

以下是一个完整的查询操作示例,展示了如何构建请求、发送请求以及解析查询结果。

 @Test
void testMatchAll() throws IOException {
    // 1.创建request对象
    SearchRequest request = new SearchRequest("items");
    // 2.配置request参数
    request.source()
            .query(QueryBuilders.matchAllQuery());
    // 3.发送请求
    SearchResponse response = client.search(request, RequestOptions.DEFAULT);

    // 4.解析结果
    SearchHits searchHits = response.getHits();
    // 4.1.总条数
    long total = searchHits.getTotalHits().value;
    System.out.println("total = " + total);
    // 4.2.命中的数据
    SearchHit[] hits = searchHits.getHits();
    for (SearchHit hit : hits) {
        // 4.2.1.获取source结果
        String json = hit.getSourceAsString();
        // 4.2.2.转为ItemDoc
        ItemDoc doc = JSONUtil.toBean(json, ItemDoc.class);
        
        System.out.println("doc = " + doc);
    }
}



总结

通过 Java Rest Client,我们可以方便地构建和发送 Elasticsearch 查询请求。查询操作的核心步骤如下:

  1. 构建请求对象:创建 SearchRequest,并设置索引库名。
  2. 构建查询条件:通过 SearchSourceBuilder 配置查询条件、分页、排序等。
  3. 发送请求:使用 client.search 方法发送请求,获取查询结果。
  4. 解析查询结果:从响应中提取 hitstotal,并遍历命中的文档,获取原始数据。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【C++】红黑树的应用(封装map和set)

✨ 青山一道同云雨,明月何曾是两乡 🌏 📃个人主页:island1314 🔥个人专栏:C学习 🚀 欢迎关注:👍点赞 &…

C# 给定欧氏平面中的一组线可以形成的三角形的数量

给定欧氏平面中的一组线可以形成的三角形的数量(Number of Triangles that can be formed given a set of lines in Euclidean Plane) 给定欧氏平面上的 n 条不同直线的集合 L {l 1 , l 2 , ………, l n }。第i 条直线由形式为 a i x b i y c i的方程给出。求出可以使用集合…

C++书籍 第一部分专业C++程序设计概述

1&#xff0c;必不可少的“hello world” #include<iostream>int main(int argc, char** argv) {std::cout << "hello world" << std::endl;return 0; } 这个是一个极其简单的程序&#xff0c;虽然没有多大简直&#xff0c;但是可以体现c程序格式方…

leetcode刷题记录(七十二)——146. LRU 缓存

&#xff08;一&#xff09;问题描述 146. LRU 缓存 - 力扣&#xff08;LeetCode&#xff09;146. LRU 缓存 - 请你设计并实现一个满足 LRU (最近最少使用) 缓存 [https://baike.baidu.com/item/LRU] 约束的数据结构。实现 LRUCache 类&#xff1a; * LRUCache(int capacity)…

微调时如何平衡新旧参数?

在微调预训练模型时&#xff0c;平衡新旧参数是一个重要的问题。合理地平衡新旧参数可以确保模型既保留预训练阶段学到的通用表示能力&#xff0c;又能够有效地适应特定任务。以下是一些常用的方法和技术来平衡新旧参数&#xff1a; ### 1. 学习率调整 **不同层使用不同的学习…

性能调优篇 四、JVM运行时参数

目录 一、三种JVM参数选项1、标准参数选项1&#xff09;特点2&#xff09;各种选项3&#xff09;-server 和 -client 2、-X参数选项3、-XX参数选项 二、添加JVM参数选项1、idea 如何添加jvm参数 三、常见的JVM参数选项1、打印设置的参数选项及其值2、堆、栈、方法区等内存大小设…

2024年博客之星主题创作|Android 开发:前沿技术、跨领域融合与就业技能展望

目录 引言 一、推动 Android 应用创新的核心力量 1.1 人工智能与机器学习的崛起 1.2 增强现实&#xff08;AR&#xff09;与虚拟现实&#xff08;VR&#xff09;的应用扩展 1.3 5G技术的推动 1.4 跨平台开发技术的成熟 1.4.1 React Native 1.4.2 Flutter 1.4.3 Taro …

汇编与逆向(一)-汇编工具简介

RadASM是一款著名的WIN32汇编编辑器&#xff0c;支持MASM、TASM等多种汇编编译器&#xff0c;Windows界面&#xff0c;支持语法高亮&#xff0c;自带一个资源编辑器和一个调试器。 一、汇编IDE工具&#xff1a;RadASM RadASM有内置的语言包 下载地址&#xff1a;RadASM asse…

Gin 源码概览 - 路由

本文基于gin 1.1 源码解读 https://github.com/gin-gonic/gin/archive/refs/tags/v1.1.zip 1. 注册路由 我们先来看一段gin代码&#xff0c;来看看最终得到的一颗路由树长啥样 func TestGinDocExp(t *testing.T) {engine : gin.Default()engine.GET("/api/user", f…

Linux网络序列化与反序列化

Linux网络序列化与反序列化 1. 前言 在网络通信中&#xff0c;互相通信的信息不一定都是字符串&#xff0c;往往一些结构化的信息也需要进行通信。理论上&#xff0c;只要服务器和客户端都自定义一个共同的协议&#xff0c;结构化的信息也能实现正常通信。但考虑到不同系统、…

实战经验:使用 Python 的 PyPDF 进行 PDF 操作

文章目录 1. 为什么选择 PyPDF&#xff1f;2. 安装 PyPDF3. PDF 文件的合并与拆分3.1 合并 PDF 文件3.2 拆分 PDF 文件 4. 提取 PDF 文本5. 修改 PDF 元信息6. PDF 加密与解密6.1 加密 PDF6.2 解密 PDF 7. 页面旋转与裁剪7.1 旋转页面7.2 裁剪页面 8. 实战经验总结 PDF 是一种非…

PhyCAGE:符合物理规律的图像到 3D 生成

Paper: Yan H, Zhang M, Li Y, et al. PhyCAGE: Physically Plausible Compositional 3D Asset Generation from a Single Image[J]. arXiv preprint arXiv:2411.18548, 2024. Introduction: https://wolfball.github.io/phycage/ Code: Unreleased PhyCAGE 是一种 image-to-3D…

游戏为什么失败?回顾某平庸游戏

1、上周玩了一个老鼠为主角的游戏&#xff0c;某平台喜1送的&#xff0c; 下载了很久而一直没空玩&#xff0c;大约1G&#xff0c;为了清硬盘空间而玩。 也是为了拔掉心中的一根刺&#xff0c;下载了而老是不玩总感觉不舒服。 2、老鼠造型比较写实&#xff0c;看上去就有些讨…

上位机工作感想-2024年工作总结和来年计划

随着工作年限的增增长&#xff0c;发现自己越来越不喜欢在博客里面写一些掺杂自己感想的东西了&#xff0c;或许是逐渐被工作逼得“成熟”了吧。2024年&#xff0c;学到了很多东西&#xff0c;做了很多项目&#xff0c;也帮别人解决了很多问题&#xff0c;唯独没有涨工资。来这…

Android系统开发(六):从Linux到Android:模块化开发,GKI内核的硬核科普

引言&#xff1a; 今天我们聊聊Android生态中最“硬核”的话题&#xff1a;通用内核镜像&#xff08;GKI&#xff09;与内核模块接口&#xff08;KMI&#xff09;。这是内核碎片化终结者的秘密武器&#xff0c;解决了内核和供应商模块之间无尽的兼容性问题。为什么重要&#x…

5G 核心网 相关概念快速入门

在我们开始阅读3GPP协议来学习5G核心网之前&#xff0c; 不妨来看看我之前整理的PPT&#xff0c;快速学习核心网相关概念&#xff0c; 以及5G转发面PFCP协议的相关核心知识。 涵盖了最精简的核心骨干内容&#xff0c;助你轻松上阵。 讲解目标 3GPP和相关协议 5G核心网架构模…

2025/1/20 学习Vue的第三天

玩性太大了玩得也不开心&#xff0c;天天看电视刷视频。 内心实在空洞。 最近天天看小红书上的外国人&#xff0c;结实外国友人&#xff08;狗头&#xff09;哈哈哈认识了不少人&#xff0c;有埃及的有美国的&#xff0c;还有天天看菲利普吃糖葫芦哈哈哈哈哈一个阳光的德国大男…

虚幻基础1:hello world

能帮到你的话&#xff0c;就给个赞吧 &#x1f618; 文章目录 hello world创建项目创建关卡创建蓝图将蓝图插入关卡中运行 hello world 本文引擎为5.5.1 创建项目 如图 创建后如图。 创建关卡 如图 创建蓝图 如图 选择actor 双击进入蓝图节点 选择事件图表 创…

SAP POC 项目完工进度 - 收入确认方式【工程制造行业】【新准则下工程项目收入确认】

1. SAP POC收入确认基础概念 1.1 定义与原则 SAP POC&#xff08;Percentage of Completion&#xff09;收入确认方式是一种基于项目完工进度来确认收入的方法。其核心原则是根据项目实际完成的工作量或成本投入占预计总工作量或总成本的比例&#xff0c;来确定当期应确认的收…

SparkSQL数据源与数据存储综合实践

文章目录 1. 打开项目2. 查看数据集2.1 查看JSON格式数据2.2 查看CSV格式数据2.3 查看TXT格式数据 3. 添加单元测试依赖4. 创建数据加载与保存对象4.1 创建Spark会话对象4.2 创建加载JSON数据方法4.3 创建加载CSV数据方法4.4 创建加载Text数据方法4.5 创建加载JSON数据扩展方法…