弹性搜索结果不一致

如何解决弹性搜索结果不一致

我的索引包含大约40.000条船名

发布查询船只名称(即“ TUC”)时,我会得到许多结果 但是,当将查询词减少为“ T”时,我从“ TUC”查询中获得的结果不在结果集中吗?

我对造成这种情况的原因有些困惑,但是想知道是否由于总结果集太大而被删去了?

一些统计

查询

{
"query" : {
    "bool" : {
        "must" : [
            {
                "query_string" : {
                    "fields" : ["vesselName"],"type" : "phrase_prefix","query" : "T"
                }
            }
        ]
    }
}

结果(第一):

"max_score": 12.450134,"hits": [
        {
            "_index": "vesselsindex","_type": "_doc","_id": "06ad4663-42f6-4771-b350-0d3b7a1b3229","_score": 12.450134,"_source": {
                "vesselId": "06ad4663-42f6-4771-b350-0d3b7a1b3229","callSign": "FATA","vesselName": "TAAPE"
            }
        },

结果(当使用搜索字词“ TUC”时):

{
            "_index": "vesselsindex","_id": "e7bea95c-6819-48b1-b52e-0a8fbaeef1df","_score": 11.831188,"_source": {
                "vesselId": "e7bea95c-6819-48b1-b52e-0a8fbaeef1df","callSign": "PBAQ","vesselName": "TUCANA"
            }
        },

设置:

{
"vesselsindex": {
    "settings": {
        "index": {
            "number_of_shards": "1","provided_name": "vesselsindex","max_result_window": "50000","creation_date": "1604061335143","analysis": {
                "analyzer": {
                    "keywordWithCaseIgnore": {
                        "filter": [
                            "lowercase"
                        ],"type": "custom","tokenizer": "keyword"
                    }
                }
            },"number_of_replicas": "1","uuid": "M-m3nIB5TqeiPNR2NR5zWQ","version": {
                "created": "7060099"
            }
        }
    }
}

统计

{
"_shards": {
    "total": 2,"successful": 1,"Failed": 0
},"_all": {
    "primaries": {
        "docs": {
            "count": 43510,"deleted": 0
        },"store": {
            "size_in_bytes": 12762612
        },

解决方法

发生这种情况是因为默认情况下,ES仅返回前10个搜索结果,而当您搜索T时,前10个文档可能是TUC查询搜索中出现的时间结果。

如果您想获得更多的搜索结果,请增加size param,这很昂贵,因此主要用于分页以提高搜索查询的性能。

您可以将size参数作为查询参数或作为搜索请求正文的一部分来提供。

您可以在搜索请求URL中尝试_search?size = 44000,它应该返回所有搜索结果

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?