需求:搜索标题中包含 java 的帖子,同时如果标题中包含 hadoop 和 elasticsearch 就优先搜索出来,同时,如果一个帖子包含 java hadoop,一个帖子包含 java elasticsearch, 包含 hadoop 的帖子要比 elasticsearch 优先搜索出来。
搜索条件的权重,boost,可以将某个搜索条件的权重加大,此时当匹配这个搜索条件和匹配另一个搜索条件的 document,计算 relevance score 时,匹配权重更大的搜索条件的 document,relevance score 会更高,当然也就会优先被返回回来。
在默认的情况下,搜索条件的权重都是一样的,都是 1
GET /forum/_search
{
"query": {
"bool": {
"must": [
{
"match": {"title": "java"}
}
],
"should": [
{
"match": {"title": "hadoop"}
},
{
"match": {"title": "elasticsearch"}
},
{
"match": {"title": "spark"}
}
]
}
}
}
这个测试不好复现,在出现的结果中如果不是我们想要的,我们可以根据上面的需求调节一下 boost,来让最后的返回结果达到我们的预期。
GET /forum/_search
{
"query": {
"bool": {
"must": [
{
"match": {"title": "java"}
}
],
"should": [
{
"match": {
"title": {
"query": "hadoop",
"boost": 5
}
}
},
{
"match": {
"title": {
"query": "elasticsearch",
"boost": 3
}
}
},
{
"match": {
"title": {
"query": "spark",
"boost": 1
}
}
}
]
}
}
}