My json is below
[{'id':1, 'name': 'christiano ronaldo', 'description': '[email protected]', 'type': 'football', 'var':'sports'},
{'id':2, 'name': 'lionel messi', 'description': '[email protected]','type': 'soccer','var':'sports'},
{'id':3, 'name': 'sachin', 'description': 'was', 'type': 'cricket', 'var':'sports'}]
My dsl query is below
{
"query": {
"bool": {
"must": [
{
"terms": {
"var.keyword": [
"sports"
]
}
}
],
"filter": {
"query_string": {
"query": "sachin* OR messi",
"fields": [
"name^1024",
"description^32"
]
}
}
}
}
}
My out
{'took': 911,
'timed_out': False,
'_shards': {'total': 1, 'successful': 1, 'skipped': 0, 'failed': 0},
'hits': {'total': {'value': 2, 'relation': 'eq'},
'max_score': 1.0,
'hits': [{'_index': 'newtestplayer',
'_type': '_doc',
'_id': '2',
'_score': 1.0,
'_source': {'id': 2,
'name': 'lionel messi',
'description': '[email protected]',
'type': 'soccer',
'var': 'sports'}},
{'_index': 'newtestplayer',
'_type': '_doc',
'_id': '3',
'_score': 1.0,
'_source': {'id': 3,
'name': 'sachin',
'description': 'was',
'type': 'cricket',
'var': 'sports'}}]}}
You can see my score is '_score':1.0
for every where. How to change that it will be according to Fields
which i mentioned
it is because you are using your query under the filter context
which just filters the documents based on the search query, and don't compute the score
of search queries.
Refer query and filter context for more info,
In order to fix that, you need to use the query context, proper query should be like
{
"query": {
"bool": {
"must": [
{
"terms": {
"var.keyword": [
"sports"
]
}
},
{
"query_string": {
"query": "sachin* OR messi",
"fields": [
"name^1024",
"description^32"
]
}
}
]
}
}
}
As it returns search results with proper scoring and executed in query context.