返回顶部
首页 > 资讯 > 精选 >SpringBoot整合ES解析搜索返回字段问题怎么解决
  • 383
分享到

SpringBoot整合ES解析搜索返回字段问题怎么解决

2023-07-05 14:07:26 383人浏览 泡泡鱼
摘要

这篇文章主要讲解了“SpringBoot整合ES解析搜索返回字段问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springBoot整合ES解析搜索返回字段问题怎么解决”吧!1.

这篇文章主要讲解了“SpringBoot整合ES解析搜索返回字段问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springBoot整合ES解析搜索返回字段问题怎么解决”吧!

    1. 数据构造

    索引2个文档到 hotel 索引中:

    PUT /hotel/_doc/1{  "title": "文雅酒店",  "city": "青岛",  "price": 556,  "create_time": "20200418120000",  "amenities": "浴池,普通停车场/充电停车场",  "full_room": false,  "location": {    "lat": 36.083078,    "lon": 120.37566  },  "praise": 10}PUT /hotel/_doc/2{  "title": "金都嘉怡假日酒店",  "city": "北京",  "price": 337,  "create_time": "20210315200000",  "amenities": "wifi,充电停车场/可升降停车场",  "full_room": false,  "location": {    "lat": 39.915153,    "lon": 116.403  },  "praise": 60}PUT /hotel/_doc/1{  "title": "文雅酒店",  "city": "青岛",  "price": 556,  "create_time": "20200418120000",  "amenities": "浴池,普通停车场/充电停车场",  "full_room": false,  "location": {    "lat": 36.083078,    "lon": 120.37566  },  "praise": 10}PUT /hotel/_doc/2{  "title": "金都嘉怡假日酒店",  "city": "北京",  "price": 337,  "create_time": "20210315200000",  "amenities": "wifi,充电停车场/可升降停车场",  "full_room": false,  "location": {    "lat": 39.915153,    "lon": 116.403  },  "praise": 60}

    2. elasticsearch 查询集群中所有索引中的所有文档

     GET /hotel/_search
    {  "took" : 499,  "timed_out" : false,  "_shards" : {    "total" : 5,    "successful" : 5,    "skipped" : 0,    "failed" : 0  },  "hits" : {    "total" : {      "value" : 2,      "relation" : "eq"    },    "max_score" : 1.0,    "hits" : [      {        "_index" : "hotel",        "_type" : "_doc",        "_id" : "2",        "_score" : 1.0,        "_source" : {          "title" : "金都嘉怡假日酒店",          "city" : "北京",          "price" : 337,          "create_time" : "20210315200000",          "amenities" : "wifi,充电停车场/可升降停车场",          "full_room" : false,          "location" : {            "lat" : 39.915153,            "lon" : 116.403          },          "praise" : 60        }      },      {        "_index" : "hotel",        "_type" : "_doc",        "_id" : "1",        "_score" : 1.0,        "_source" : {          "title" : "文雅酒店",          "city" : "青岛",          "price" : 556,          "create_time" : "20200418120000",          "amenities" : "浴池,普通停车场/充电停车场",          "full_room" : false,          "location" : {            "lat" : 36.083078,            "lon" : 120.37566          },          "praise" : 10        }      }    ]  }}

    3. ElasticSearch 搜索结果字段解析

    1. took 搜索请求耗费了多少毫秒

    took 值告诉我们执行整个搜索请求耗费了多少毫秒。

    2. shards 查询中参与分片的总数

    _shards 部分告诉我们在查询中参与分片的总数,以及这些分片成功了多少个失败了多少个。正常情况下我们不希望分片失败,但是分片失败是可能发生的。如果我们遭遇到一种灾难级别的故障,在这个故障中丢失了相同分片的原始数据和副本,那么对这个分片将没有可用副本来对搜索请求作出响应。假若这样,Elasticsearch 将报告这个分片是失败的,但是会继续返回剩余分片的结果。

    3. timed_out 查询是否超时

    timed_out 值告诉我们查询是否超时。默认情况下,搜索请求不会超时。

    4. hits 表示搜索结果

    返回结果中最重要的部分是 hits ,它包含 total 字段来表示匹配到的文档总数,并且一个 hits 数组包含所查询结果的前十个文档。在解析搜索结果时,我们通常需要关注以下几个字段:

    hits.total.value:匹配的文档总数。
    hits.max_score:与查询所匹配文档的_score的最大值。
    hits.hits:匹配的文档列表。
    hits.hits._source:匹配的文档的原始数据。
    hits.hits._score:匹配的文档的分数。它衡量了文档与查询的匹配程度,默认情况下,首先返回最相关的文档结果,就是说,返回的文档是按照score 降序排列的。
    hits.hits.highlight:匹配的文档的高亮显示信息。

    4. SpringBoot 整合ElasticSearch获取搜索结果

    @Slf4j@Servicepublic class ElasticSearchImpl {    @Autowired    private RestHighLevelClient restHighLevelClient;    public void searchUser() throws IOException {        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();        SearchRequest searchRequest = new SearchRequest(new String[]{"hotel"},searchSourceBuilder);        SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);        TimeValue took = searchResponse.getTook();        System.out.println("took = " + took);        // 搜索结果        SearchHits searchHits = searchResponse.getHits();        // hits.total.value:匹配的文档总数        TotalHits totalHits = searchHits.getTotalHits();        long value = totalHits.value;        System.out.println("value = " + value);        // hits.max_score:与查询所匹配文档的_score的最大值        float maxScore = searchHits.getMaxScore();        System.out.println("maxScore = " + maxScore);        // hits.hits:匹配的文档列表        SearchHit[] hits = searchHits.getHits();        for (SearchHit hit : hits) {            // hits.hits._source:匹配的文档的原始数据            String sourceAsString = hit.getSourceAsString();            System.out.println("sourceAsString = " + sourceAsString);            //  hits.hits._id:匹配的文档的id            String id = hit.getId();            System.out.println("id = " + id);            Map<String, DocumentField> fields = hit.getFields();            System.out.println("fields = " + fields);            String index = hit.getIndex();            System.out.println("index = " + index);            float score = hit.getScore();            System.out.println("score = " + score);        }        System.out.println(searchResponse);    }}@Slf4j@Servicepublic class ElasticSearchImpl {    @Autowired    private RestHighLevelClient restHighLevelClient;    public void searchUser() throws IOException {        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();        SearchRequest searchRequest = new SearchRequest(new String[]{"hotel"},searchSourceBuilder);        SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);        TimeValue took = searchResponse.getTook();        System.out.println("took = " + took);        // 搜索结果        SearchHits searchHits = searchResponse.getHits();        // hits.total.value:匹配的文档总数        TotalHits totalHits = searchHits.getTotalHits();        long value = totalHits.value;        System.out.println("value = " + value);        // hits.max_score:与查询所匹配文档的_score的最大值        float maxScore = searchHits.getMaxScore();        System.out.println("maxScore = " + maxScore);        // hits.hits:匹配的文档列表        SearchHit[] hits = searchHits.getHits();        for (SearchHit hit : hits) {            // hits.hits._source:匹配的文档的原始数据            String sourceAsString = hit.getSourceAsString();            System.out.println("sourceAsString = " + sourceAsString);            //  hits.hits._id:匹配的文档的id            String id = hit.getId();            System.out.println("id = " + id);            Map<String, DocumentField> fields = hit.getFields();            System.out.println("fields = " + fields);            String index = hit.getIndex();            System.out.println("index = " + index);            float score = hit.getScore();            System.out.println("score = " + score);        }        System.out.println(searchResponse);    }}
    took=2msvalue = 2maxScore = 1.0sourceAsString = {"title":"金都嘉怡假日酒店","city":"北京","price":337,"create_time":"20210315200000","amenities":"wifi,充电停车场/可升降停车场","full_room":false,"location":{"lat":39.915153,"lon":116.403},"praise":60}id = 2fields = {}index = hotelscore = 1.0sourceAsString = {"title":"文雅酒店","city":"青岛","price":556,"create_time":"20200418120000","amenities":"浴池,普通停车场/充电停车场","full_room":false,"location":{"lat":36.083078,"lon":120.37566},"praise":10}id = 1fields = {}index = hotelscore = 1.0
    {    "took": 2,    "timed_out": false,    "_shards": {        "total": 5,        "successful": 5,        "skipped": 0,        "failed": 0    },    "hits": {        "total": {            "value": 2,            "relation": "eq"        },        "max_score": 1.0,        "hits": [            {                "_index": "hotel",                "_type": "_doc",                "_id": "2",                "_score": 1.0,                "_source": {                    "title": "金都嘉怡假日酒店",                    "city": "北京",                    "price": 337,                    "create_time": "20210315200000",                    "amenities": "wifi,充电停车场/可升降停车场",                    "full_room": false,                    "location": {                        "lat": 39.915153,                        "lon": 116.403                    },                    "praise": 60                }            },            {                "_index": "hotel",                "_type": "_doc",                "_id": "1",                "_score": 1.0,                "_source": {                    "title": "文雅酒店",                    "city": "青岛",                    "price": 556,                    "create_time": "20200418120000",                    "amenities": "浴池,普通停车场/充电停车场",                    "full_room": false,                    "location": {                        "lat": 36.083078,                        "lon": 120.37566                    },                    "praise": 10                }            }        ]    }}

    5 .ElasticSearch 搜索结果的面试题

    ElasticSearch 搜索结果中的 _score 字段是什么意思?

    答:_score 字段表示匹配文档的相关度得分,分数越高表示匹配度越高。

    ElasticSearch 搜索结果中的 highlight 字段是什么意思?

    答:highlight 字段表示匹配文档中被高亮显示的字段及其高亮显示的内容。

    如何获取 ElasticSearch 搜索结果中的总文档数?

    答:可以通过 hits.total.value 字段获取匹配的文档总数。

    如何获取 ElasticSearch 搜索结果中的匹配文档列表?

    答:可以通过 hits.hits 字段获取匹配的文档列表。

    如何获取 ElasticSearch 搜索结果中匹配文档的原始数据?

    答:可以通过 hits.hits._source 字段获取匹配文档的原始数据。

    如何获取 ElasticSearch 搜索结果中匹配文档的高亮显示信息?

    答:可以通过 hits.hits.highlight 字段获取匹配文档的高亮显示信息。

    ElasticSearch 搜索结果中的 _shards 字段是什么意思?

    答:_shards 字段表示搜索涉及的分片信息,包括总分片数、成功的分片数、跳过的分片数和失败的分片数。

    ElasticSearch 搜索结果中的 took 字段是什么意思?

    答:took 字段表示搜索耗时,单位为毫秒。

    感谢各位的阅读,以上就是“SpringBoot整合ES解析搜索返回字段问题怎么解决”的内容了,经过本文的学习后,相信大家对SpringBoot整合ES解析搜索返回字段问题怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    --结束END--

    本文标题: SpringBoot整合ES解析搜索返回字段问题怎么解决

    本文链接: https://lsjlt.com/news/352388.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • SpringBoot整合ES解析搜索返回字段问题
      目录1. 数据构造2. ElasticSearch 查询集群中所有索引中的所有文档3. ElasticSearch 搜索结果字段解析1. took 搜索请求耗费了多少毫秒2. sha...
      99+
      2023-03-21
      SpringBoot整合ES SpringBoot整合ES搜索返回字段
    • SpringBoot整合ES解析搜索返回字段问题怎么解决
      这篇文章主要讲解了“SpringBoot整合ES解析搜索返回字段问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot整合ES解析搜索返回字段问题怎么解决”吧!1. ...
      99+
      2023-07-05
    • SpringBoot如何整合ES解析搜索返回字段问题
      这篇文章主要讲解了“SpringBoot如何整合ES解析搜索返回字段问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot如何整合ES解析搜索返回字段问题”吧!1. 数据构造...
      99+
      2023-07-06
    • MySql中的longtext字段的返回问题及解决
      目录mysql中longtext字段的返回如下图所示解决方法Mysql中Text字段的范围汉字在utf8mb4中占用几个字符MySql中longtext字段的返回 最近开发中用到了longtext这种字段。在mysq...
      99+
      2022-07-05
      MySql中longtext字段 longtext字段返回 MySql的longtext
    • springboot拦截返回数据问题怎么解决
      在Spring Boot中,可以使用拦截器来拦截返回数据,并对返回数据进行处理。可以按照以下步骤来解决该问题:1. 创建一个实现了`...
      99+
      2023-10-12
      springboot
    • MySql中的longtext字段的返回问题如何解决
      这篇文章主要介绍了MySql中的longtext字段的返回问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySql中的longtext字段的返回问题如何解决文章都会有所收获,下面我们一起来看看吧。M...
      99+
      2023-07-02
    • es字段修改后检索不到怎么解决
      如果在修改了ES字段后无法检索到数据,可能有以下几个可能的原因和解决方法: 索引重建:如果修改了字段类型或映射,可能需要重新创建...
      99+
      2023-10-24
      es
    • SpringBoot整合Lombok及常见问题怎么解决
      这篇文章主要介绍“SpringBoot整合Lombok及常见问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringBoot整合Lombok及常见问题怎么解决”文章能帮助大家解决问题。...
      99+
      2023-06-30
    • springboot接口返回字符串带引号的问题解决
      目录框架版本问题排查问题所在解决方法参考资料框架版本 springboot 2.2.1.RELEASEfastjson 1.2.78 maven pom.xml parent 和 d...
      99+
      2024-04-02
    • PHP整数取余返回负数的问题怎么解决
      本篇内容介绍了“PHP整数取余返回负数的问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!PHP语言虽然功能强大,但并不代表其没有缺...
      99+
      2023-06-17
    • 怎么解决springBoot整合Eureka启动失败的问题
      这篇文章主要介绍“怎么解决springBoot整合Eureka启动失败的问题”,在日常操作中,相信很多人在怎么解决springBoot整合Eureka启动失败的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
      99+
      2023-06-20
    • Springboot调整接口响应返回时长详解(解决响应超时问题)
      目录配置Http会话超时application.properties中配置会话超时以程序方式配置会话超时配置接口访问超时一、配置文件方式二、配置Config配置类需要避免踩到的坑to...
      99+
      2023-01-30
      springboot响应过长问题 springboot响应慢
    • Springboot调整接口响应返回时长(解决响应超时问题)
      Springboot调整接口/会话响应返回时长(解决响应超时问题) 配置Http会话超时 可以通过两种方式为Spring Boot应用程序配置HTTP会话超时。 application.propert...
      99+
      2023-10-02
      spring boot java servlet
    • SpringBoot拦截器返回false显示跨域问题怎么解决
      本文小编为大家详细介绍“SpringBoot拦截器返回false显示跨域问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“SpringBoot拦截器返回false显示跨域问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢...
      99+
      2023-06-30
    • 怎么解决php ajax返回乱码问题
      本篇内容主要讲解“怎么解决php ajax返回乱码问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决php ajax返回乱码问题”吧!php ajax返回乱码的解决办法:1、在php的a...
      99+
      2023-06-25
    • java只返回实体类中的部分字段问题如何解决
      这篇文章主要介绍了只返回实体类中的部分字段问题如何解决,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。如何只返回实体类中的部分字段在实体类上添加注解@JsonInclude(JsonInclude.Include.NON_...
      99+
      2023-07-06
    • 怎么解决Struts Hibernate的整合问题
      这篇文章主要介绍“怎么解决Struts Hibernate的整合问题”,在日常操作中,相信很多人在怎么解决Struts Hibernate的整合问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么解决Str...
      99+
      2023-06-17
    • ajax回调函数返回的字符串乱码问题怎么解决
      本篇内容主要讲解“ajax回调函数返回的字符串乱码问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ajax回调函数返回的字符串乱码问题怎么解决”吧! ...
      99+
      2024-04-02
    • 怎么解决php curl没有返回值的问题
      本篇内容介绍了“怎么解决php curl没有返回值的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!php curl没有返回值的解决办法:...
      99+
      2023-06-22
    • java递归函数返回值问题怎么解决
      在递归函数中,可以使用一个参数或者一个全局变量来保存计算结果,然后在递归调用的过程中更新这个参数或者变量的值,最终返回最终的结果。例...
      99+
      2023-09-26
      java
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作