我有一个 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 低于其他的?
答案 0 :(得分:1)
作为一种解决方法,我发现了以下内容:
{
"compound": {
"should": [
{
"phrase": {
"query": "The American",
"path": "name",
"score": { "boost": {"value": 5}}
}},
{
"autocomplete": {
"query": "The American",
"path": "name"}
}
]
}
}
词组匹配的分数提升将处理精确匹配并使精确匹配分数高于其他分数。