美文网首页elasticsearch
ES搜索补全建议一

ES搜索补全建议一

作者: rainbowz | 来源:发表于2021-12-13 00:41 被阅读0次

当用户在搜索框输入字符时,我们应该提示出与该字符有关的搜索项,如图


image.png

elasticsearch提供了Completion Suggesttion查询实现自动补全。为了提高补全查询的效率,对于文档字段的类型有限制

  • 参与补全查询的字段必须是completetion类型
  • 字段的内容一般是用来补全的多个字条组成的数组
PUT test
{
"mappings": {
"  properties": {
  "title":{
  "type": "completion"
      }
    }
  }
}

插入下面数据

// 示例数据
POST test/_doc
{
"title": ["Sony", "WH-1000XM3"]
}
POST test/_doc
{
"title": ["SK-II", "PITERA"]
}
POST test/_doc
{
"title": ["Nintendo", "switch"]
}

查询的DSL语句如下

// 自动补全查询
GET /test/_search
{
"suggest": {
"title_suggest": {
"text": "s", // 关键字
"completion": {
"field": "title", // 补全查询的字段
"skip_duplicates": true, // 跳过重复的
"size": 10 // 获取前10条结果
        }
      }
  }
}
搜索补全结果

实现酒店搜索框的自动补全

1修改hotel索引的索引库结构,设置自定义拼音分词器
2修改索引库需要被自定义分词字段那么/all
3索引库添加一个新字段suggestion,类型为completetion类型,使用我们自己自定义分词器
4给HotelDoc类添加suggestestion字段,内容包含brand、business
5重新导入数据到hotel库

酒店索引映射结构
PUT /hotel
{
  "settings": {
    "analysis": {
      "analyzer": {
        "text_anlyzer": {
          "tokenizer": "ik_max_word",
          "filter": "py"
        },
        "completion_analyzer": {
          "tokenizer": "keyword",
          "filter": "py"
        }
      },
      "filter": {
        "py": {
          "type": "pinyin",
          "keep_full_pinyin": false,
          "keep_joined_full_pinyin": true,
          "keep_original": true,
          "limit_first_letter_length": 16,
          "remove_duplicated_term": true,
          "none_chinese_pinyin_tokenize": false
        }
      }
    }
  },
  "mappings": {
    "properties": {
      "id":{
        "type": "keyword"
      },
      "name":{
        "type": "text",
        "analyzer": "text_anlyzer",
        "search_analyzer": "ik_smart",
        "copy_to": "all"
      },
      "address":{
        "type": "keyword",
        "index": false
      },
      "price":{
        "type": "integer"
      },
      "score":{
        "type": "integer"
      },
      "brand":{
        "type": "keyword",
        "copy_to": "all"
      },
      "city":{
        "type": "keyword"
      },
      "starName":{
        "type": "keyword"
      },
      "business":{
        "type": "keyword",
        "copy_to": "all"
      },
      "location":{
        "type": "geo_point"
      },
      "pic":{
        "type": "keyword",
        "index": false
      },
      "all":{
        "type": "text",
        "analyzer": "text_anlyzer",
        "search_analyzer": "ik_smart"
      },
      "suggestion":{
          "type": "completion",
          "analyzer": "completion_analyzer"
      }
    }
  }
}

JAVA类

@Data
@NoArgsConstructor
public class HotelDoc {
    private Long id;
    private String name;
    private String address;
    private Integer price;
    private Integer score;
    private String brand;
    private String city;
    private String starName;
    private String business;
    private String location;
    private String pic;
    private Object distance;
    private Boolean isAD;
    private List<String> suggestion;

 public HotelDoc(Hotel hotel) {
        this.id = hotel.getId();
        this.name = hotel.getName();
        this.address = hotel.getAddress();
        this.price = hotel.getPrice();
        this.score = hotel.getScore();
        this.brand = hotel.getBrand();
        this.city = hotel.getCity();
        this.starName = hotel.getStarName();
        this.business = hotel.getBusiness();
        this.location = hotel.getLatitude() + ", " + hotel.getLongitude();
        this.pic = hotel.getPic();

        // 判断商圈是否包含/
        if (this.business.contains("/")) {
            // 需要切割
            String[] arr = this.business.split("/");
            this.suggestion = new ArrayList<>();
            this.suggestion.add(this.brand);
            Collections.addAll(this.suggestion, arr);
        } else {
            this.suggestion = Arrays.asList(this.brand, this.business);
        }

    }
}

重新导入数据,编写DSL语句


image.png 测试补全 参考图片 解析语句

参考
elasticsearch系列五:搜索详解(查询建议介绍、Suggester 介绍

相关文章

  • ES搜索补全建议一

    当用户在搜索框输入字符时,我们应该提示出与该字符有关的搜索项,如图 elasticsearch提供了Complet...

  • ES Suggester 搜索自动补全

    需求 将商品表数据全量更新至ES索引商品索引支持Suggester自动补全,支持过滤商品enable和delete...

  • 聚焦Python分布式爬虫必学框架 Scrapy 打造搜索引擎

    了解搜索网站大体功能 搜索网站首页 搜索网站搜素结果页 es完成搜索建议-搜索建议字段保存 事实上 elastic...

  • 2018-07-20-ElasticSearch-搜索建议实现

    本文将会完整的讲述ES中搜索建议的程序实现。在网上搜索的教程当中大部分都是使用的ES的TransportClien...

  • elasticsearch5.2搜索建议(自动补全)

    问题描述 电商网站的搜索是最基础最重要的功能之一,搜索框上面的良好体验能为电商带来更高的收益,我们先来看看淘宝、京...

  • es读优化

    es搜索数据 es搜索数据流程 es读写流程示意图 分布式搜索示意图image.png es的几种搜索类型 QUE...

  • zsh

    功能与特性 grep + 上下键 可以搜索grep最近的命令 智能纠错拼写 各种补全:路径补全、命令补全、命令参数...

  • 2022-01-15

    示例文章:Google 搜索的即时自动补全功能究竟是如何“工作”的? Google 搜索自动补全功能的强大,相信不...

  • es

    数据迁移 es,es是一个开源的搜索引擎,es包括数据存储和数据检索,搜索数据会比 mysql 快很多,搜索接口是...

  • LInux Day10: bash特性

    bash及其特性: 光标跳转: 命令历史: Tab 命令补全:Tab(命令搜索路径下) 路径补全全:Tab 环境变...

网友评论

    本文标题:ES搜索补全建议一

    本文链接:https://www.haomeiwen.com/subject/qyodfrtx.html