elasticsearch高级功能系列之completion suggest

本文探讨了Elasticsearch中的Completion Suggester,如何在mapping中配置内部fields,使用ik分词器处理中文。在添加数据后,通过示例展示了如何进行建议查询。响应中包含了用于搜索提示的text字段,可以将其返回给前端展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、首先创建mapping,注意,在需要建议的field创建一个内部fields,suggest,类型是completion ,因为处理的是中文,所以加了ik中文分词器。

{
 "mappings": {
      "book": {
        "properties": {
          "bookAuthor": {
            "type": "text",
            "fields": {
              "keyword": {
                "type": "keyword",
                "ignore_above": 256
              },
              "suggest": {
                "type": "completion",
                "analyzer": "ik_max_word"
          
              }
            }
        }  
 }

2、添加数据以后,就可以suggest了

GET book/book/_search
{
 "suggest":{
   "mysuggest":{
     "prefix":"三",
     "completion":{
       "field":"bookAuthor.suggest"
     }
   }
 }
}

 3、这是我es中的响应,注意返回的text字段,就是建议器给出的建议,如果要做搜索提示,可以将多个text封装起来返回给前台展示。

{
  "took": 115,
  "timed_out": false,
  "_shards": {
    "total": 5,
    "successful": 5,
    "skipped": 0,
    "failed": 0
  },
  "hits": {
    "total": 0,
    "max_score": 0,
    "hits": []
  },
  "suggest": {
    "mysuggest": [
      {
        "text": "三",
        "offset": 0,
        "length": 1,
        "options": [
          {
            "text": "三戒大师",
            "_index": "book",
            "_type": "book",
            "_id": "AWUyRthtLhso7IaOhgG4",
            "_score": 1,
            "_source": {
              "bookAuthor": "三戒大师"
            }
          },
          {
            "text": "三毛",
            "_index": "book",
            "_type": "book",
            "_id": "AWUyRthtLhso7IaOhf9W",
            "_score": 1,
            "_source": {
              "bookAuthor": "三毛"
            }
        ]
      }
    ]
  }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值