ES實現搜素建議

1. 什麼是搜索建議?

幫助⽤戶在搜索的過程,對輸入中進行糾錯,提示建議性詞語。
例如:

2. ES實現原理

輸⼊的⽂本分解爲 Token,然後在索引的字典裏查找相似的 Term 並返回。

3. 對應API,Term& Phrase Suggester

TermSuggester

3種Suggestion Mode

Missing – 如索引中已經存在,就不提供建議
Popular – 推薦出現頻率更加⾼的詞
Always – ⽆論是否存在,都提供建議

一個排序

默認按照 score 排序,也可以按照“frequency”

首字母限制

默認⾸字⺟不⼀致,就不會匹配推薦。解決方法,將 prefix_length 設置爲 0,
Phrase Suggester
Suggest Mode :missing, popular, always 
Max Errors:最多可以拼錯的 Terms 數
Confidence:限制返回結果數,默認爲1,只有分數高過設定值時,纔會返回。

4. 例子

# 刪除之前的Index
DELETE articles
# 插入2個測試數據
POST articles/_bulk
{ "index" : { } }
{ "body": "elasticsearch is good"}
{ "index" : { } }
{ "body": "elasticsearch is ok"}
2. 調用查詢api
POST /articles/_search
{
  "size": 1,
  "query": {
    "match": {
      "body": "elasticseach"
    }
  },
  "suggest": {
    "term-suggestion": {
      "text": "elasticseach",
      "term": {
        "suggest_mode": "missing",
        "field": "body"
      }
    }
  }
}

對應結果

{
  "took" : 13,
  "timed_out" : false,
  "_shards" : {
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : {
      "value" : 0,
      "relation" : "eq"
    },
    "max_score" : null,
    "hits" : [ ]
  },
  "suggest" : {
    "term-suggestion" : [
      {
        "text" : "elasticseach",
        "offset" : 0,
        "length" : 12,
        "options" : [
          {
            "text" : "elasticsearch",
            "score" : 0.9166667,
            "freq" : 2
          }
        ]
      }
    ]
  }
}

option部分就是對應的推薦詞

5. 引用文檔

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章