1. 最佳字段
假设有个网站允许用户搜索博客的内容,以下面两篇博客内容文档为例:
PUT /my_index/my_type/1
{
"title": "Quick brown rabbits",
"body": "Brown rabbits are commonly seen."
}
PUT /my_index/my_type/2
{
"title": "Keeping pets healthy",
"body": "My quick brown fox eats rabbits on a regular basis."
}
此时用户搜索 " brown fox ",用肉眼判断文档二更匹配。 由于不知道该搜索词出现的字段,所以我们用 bool 查询进行查询。
{
"query": {
"bool": {
"should": [
{ "match": { "title": "Brown fox" }},
{ "match": { "body": "Brown fox" }}
]
}
}
}
但在返回的结果中文档 1 比 文档 2 的相关度高,因为搜索时,会将每个字段的相关度相加然后计算总评分,文档一的 title 和 body 中都包含 Brown, 所以评分较高,如果不是将每个字段的评分想加,而是将最佳匹配字段的评分作为查询的整体评分,返回的结果将是同时包含 br