MongoDB Atlas 搜索自动完成索引错误评分

问题描述

我有一个 MongoDB Atlas 搜索索引,字段名称具有自动完成类型和以下属性

maxGrams : 15
minGrams : 2
tokenization: edgeGram
fold diacritics: true

该集合包含以下名称

The American
The American Equity Underwriters
The American Prairie Foundation
The American Conservatory Theater
The American Club

使用此自动完成查询

{
  autocomplete: {
    query: 'The American',path: 'name'
  }
}

我可以使用以下 searchscore 检索上述所有名称

The American Conservatory Theater -> 15.474836349487305
The American Equity Underwriters -> 15.379003524780273
The American Prairie Foundation -> 15.379003524780273
The American Club -> 15.271049499511719
The American -> 13.68109130859375

即使 The America 是完全匹配的,它也会得到较低的分数。

为什么完全匹配的 searchscore 低于其他的?

解决方法

作为一种解决方法,我发现了以下内容:

{
  "compound": { 
    "should": [
      {
      "phrase": {
        "query": "The American","path": "name","score": { "boost": {"value": 5}}
      }},{
      "autocomplete": { 
        "query": "The American","path": "name"}
    }
    ]
  }
}

词组匹配的分数提升将处理精确匹配并使精确匹配分数高于其他分数。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...