Хорошо. Вот что я сделал
1) created the mappings for the data
2) indexed 3 documents. One document is same one as you posted above and one
is completely irrelevant data, and the third document has one search field
matching, so less relevance than the first document but more relevance
than the other document
3) the search query
, когда я запустил поиск, наиболее релевантный документ показывался вверху с наибольшим количеством совпадений, а затем второй документ.
Также обратите внимание, чтоЯ передаю несколько строк, как вы ожидали, используя двойные кавычки и одинарные кавычки в поисковом запросе.Вы можете создать массив строк или строку с конкатенированными строками (с пробелами, как вы хотели и т. Д.) .. должно работать
Вот отображение
PUT ugi-index2
{
"mappings": {
"_doc": {
"properties":{
"skills": {"type": "text"},
"languages": {"type": "keyword"}
}
}
}
}
и три документа, которые яindexed
POST /ugi-index2/_doc/3
{
"skills" : [
"no skill",
"Facebook ads",
"not related"
],
"languages": [
"ab",
"cd"
]
}
POST /ugi-index2/_doc/2
{
"skills" : [
"no skill",
"test skill",
"not related"
],
"languages": [
"ab",
"cd"
]
}
POST /ugi-index2/_doc/1
{
"skills" : [
"Online strategi",
"Facebook Ads",
"Google Ads"
],
"languages": [
"da",
"en"
]
}
И поисковый запрос
GET /ugi-index2/_search
{
"query":{
"multi_match": {
"query": "'Online Strate', 'Facebook'",
"fields": ["skills"]
}
}
}
посмотрите на приведенный выше запрос для нескольких строк с пробелами (для поиска)
и вот ответ
{
"took" : 8,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : 2,
"max_score" : 0.5753642,
"hits" : [
{
"_index" : "ugi-index2",
"_type" : "_doc",
"_id" : "1",
"_score" : 0.5753642,
"_source" : {
"skills" : [
"Online strategi",
"Facebook Ads",
"Google Ads"
],
"languages" : [
"da",
"en"
]
}
},
{
"_index" : "ugi-index2",
"_type" : "_doc",
"_id" : "3",
"_score" : 0.2876821,
"_source" : {
"skills" : [
"no skill",
"Facebook ads",
"not related"
],
"languages" : [
"ab",
"cd"
]
}
}
]
}
}