前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ES实现搜素建议

ES实现搜素建议

原创
作者头像
温安适
修改2021-02-22 10:22:41
9630
修改2021-02-22 10:22:41
举报
文章被收录于专栏:温安适的blog温安适的blog

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. 例子

代码语言:javascript
复制
# 删除之前的Index
DELETE articles
# 插入2个测试数据
POST articles/_bulk
{ "index" : { } }
{ "body": "elasticsearch is good"}
{ "index" : { } }
{ "body": "elasticsearch is ok"}

2. 调用查询api

代码语言:javascript
复制
POST /articles/_search
{
  "size": 1,
  "query": {
    "match": {
      "body": "elasticseach"
    }
  },
  "suggest": {
    "term-suggestion": {
      "text": "elasticseach",
      "term": {
        "suggest_mode": "missing",
        "field": "body"
      }
    }
  }
}

对应结果

代码语言:javascript
复制
{
  "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. 引用文档

https://www.elastic.co/guide/en/elasticsearch/reference/7.1/search-suggesters.html

https://www.elastic.co/guide/en/elasticsearch/reference/7.1/search-suggesters-term.html

https://www.elastic.co/guide/en/elasticsearch/reference/7.1/search-suggesters-phrase.html

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 什么是搜索建议?
  • 2. ES实现原理
  • 3. 对应API,Term& Phrase Suggester
    • TermSuggester
      • 3种Suggestion Mode
      • 一个排序
      • 首字母限制
  • 4. 例子
  • 5. 引用文档
相关产品与服务
Elasticsearch Service
腾讯云 Elasticsearch Service(ES)是云端全托管海量数据检索分析服务,拥有高性能自研内核,集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群,也支持免运维、自动弹性、按需使用的 Serverless 模式。使用 ES 您可以高效构建信息检索、日志分析、运维监控等服务,它独特的向量检索还可助您构建基于语义、图像的AI深度应用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档