Нет прямого способа сделать это, однако вы можете достичь этого следующим способом, где вам нужно будет добавить параметры запроса в two различных частей запроса.
До этого важного примечания вы не можете применить doc['myfield'].value
, если поле имеет тип text
, вместо этого вам нужно, чтобы его родственное поле было создано как keyword
и сослаться на это в сценарии, который я уже упоминал ниже:
Отображение:
PUT myindex
{
"mappings" : {
"properties" : {
"myfield" : {
"type" : "text",
"fields" : {
"keyword" : {
"type" : "keyword",
"ignore_above" : 256
}
}
}
}
}
}
Образец документа:
POST myquery/_doc/1
{
"myfield": "I've become comfortably numb"
}
Запрос:
POST <your_index_name>/_search
{
"query": {
"function_score": {
"query": {
"match": {
"myfield": "numb"
}
},
"functions": [
{
"script_score": {
"script": {
"source": "return doc['myfield.keyword'].value.length() - params.myquery.length()",
"params": {
"myquery": "numb" <---- Add the query string here as well
}
}
}
}
],
"boost_mode": "replace"
}
}
}
Ответ:
{
"took" : 558,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 24.0,
"hits" : [
{
"_index" : "myindex",
"_type" : "_doc",
"_id" : "1",
"_score" : 24.0,
"_source" : {
"myfield" : "I've become comfortably numb"
}
}
]
}
}
Надеюсь, это поможет!