2016-03-02 04:51:47 -05:00
[[mapping-boost]]
2015-08-06 11:24:29 -04:00
=== `boost`
2020-01-24 11:05:42 -05:00
Individual fields can be _boosted_ automatically -- count more towards the relevance score
-- at query time, with the `boost` parameter as follows:
2015-08-06 11:24:29 -04:00
2019-09-06 11:31:13 -04:00
[source,console]
2015-08-06 11:24:29 -04:00
--------------------------------------------------
2020-07-27 15:58:26 -04:00
PUT my-index-000001
2015-08-06 11:24:29 -04:00
{
"mappings": {
2019-01-22 09:13:52 -05:00
"properties": {
"title": {
"type": "text",
"boost": 2 <1>
},
"content": {
"type": "text"
2015-08-06 11:24:29 -04:00
}
}
}
}
--------------------------------------------------
2020-09-18 11:44:40 -04:00
// TEST[warning:Parameter [boost] on field [title] is deprecated and will be removed in 8.0]
2015-08-06 11:24:29 -04:00
<1> Matches on the `title` field will have twice the weight as those on the
`content` field, which has the default `boost` of `1.0`.
2016-03-02 04:51:47 -05:00
NOTE: The boost is applied only for term queries (prefix, range and fuzzy queries are not _boosted_).
2015-08-06 11:24:29 -04:00
2016-03-02 04:51:47 -05:00
You can achieve the same effect by using the boost parameter directly in the query, for instance the following query (with field time boost):
2019-09-06 11:31:13 -04:00
[source,console]
2016-03-02 04:51:47 -05:00
--------------------------------------------------
2016-04-29 10:42:03 -04:00
POST _search
2016-03-02 04:51:47 -05:00
{
2020-07-22 15:57:49 -04:00
"query": {
"match": {
"title": {
"query": "quick brown fox"
}
2016-03-02 04:51:47 -05:00
}
2020-07-22 15:57:49 -04:00
}
2016-03-02 04:51:47 -05:00
}
--------------------------------------------------
is equivalent to:
2019-09-06 11:31:13 -04:00
[source,console]
2016-03-02 04:51:47 -05:00
--------------------------------------------------
2016-04-29 10:42:03 -04:00
POST _search
2016-03-02 04:51:47 -05:00
{
2020-07-22 15:57:49 -04:00
"query": {
"match": {
"title": {
"query": "quick brown fox",
"boost": 2
}
2016-03-02 04:51:47 -05:00
}
2020-07-22 15:57:49 -04:00
}
2016-03-02 04:51:47 -05:00
}
--------------------------------------------------
2019-04-30 15:50:52 -04:00
deprecated[5.0.0, "Index time boost is deprecated. Instead, the field mapping boost is applied at query time. For indices created before 5.0.0, the boost will still be applied at index time."]
2015-08-06 11:24:29 -04:00
[WARNING]
.Why index time boosting is a bad idea
==================================================
We advise against using index time boosting for the following reasons:
* You cannot change index-time `boost` values without reindexing all of your
documents.
* Every query supports query-time boosting which achieves the same effect. The
difference is that you can tweak the `boost` value without having to reindex.
* Index-time boosts are stored as part of the <<norms,`norm`>>, which is only one
byte. This reduces the resolution of the field length normalization factor
which can lead to lower quality relevance calculations.
2016-03-18 12:01:27 -04:00
==================================================