ElasticSearch 搜索推荐

Term Suggester

java 复制代码
"suggest_mode":"missing"  missing 默认选项,不返回精准匹配到的分词结果
"suggest_mode":"popular"  popular 大于等于搜索词频率的返回
"suggest_mode":"always", 不做任何限制
 "min_doc_freq":2		出现在文档中的次数大于min_doc_freq的才返回,同一文档中多次出现算一次。
 GET /product/_search
{
  "suggest": {
    "desc_suggest": {
      "text":"手机中的",
      "term":{
        "field":"desc",
        "suggest_mode":"popular",
        "min_doc_freq":2
      }
    }
  }
}

Completion Suggester

java 复制代码
基于内存而非索引(内存消耗大),性能好,只适合前缀搜索
结果精准度高召回率低

#添加新字段 设置suggest
PUT /product/_mapping
{
  "properties": {
    "desc_sugg": {
      "type": "text",
      "analyzer": "ik_max_word",
      "fields": {
        "suggest": {
          "type": "completion",
          "analyzer": "ik_max_word"
        }
      }
    }
  }
}

#给新字段赋值
POST /product/_update_by_query
{
  "script": {
    "source": "ctx._source.desc_sugg=ctx._source.desc",
    "lang": "painless"
  },
  "query": {
    "match_all": {}
  }
}
# "skip_duplicates":true, 结果去重  
# "fuzziness":2 允许容错数
GET /product/_search
{
  "suggest": {
    "desc_suggest": {
      "prefix": "耳机",
      "completion": {
        "field": "desc_sugg.suggest",
        "skip_duplicates":true,
        "fuzzy":{
          "fuzziness":2
        }
      }
    }
  }
}

Context Suggester

java 复制代码
新增索引
PUT product_suggest
{
  "mappings": {
    "properties": {
      "suggest": {
        "type": "completion",
        "contexts": [
          {
            "name": "place_type",
            "type": "category",
            "path": "tags"
          },
          {
            "name": "localtion",
            "type": "geo",
            "path": "loc",
            "precision": 4
          }
        ]
      },
      "loc":{
        "type": "geo_point"
      }
    }
  }
}
新增数据
PUT /product_suggest/_doc/1
{
  "suggest":["hello","word","tremhhh"],
  "tags":["no","hh"]
}

PUT /product_suggest/_doc/2
{
  "suggest":["hellhho","word","treeemhhh"],
  "tags":["monely"]
}

PUT /product_suggest/_doc/3
{
  "suggest": [
    "latlon",
    "word",
    "tremhhh"
  ],
  "loc": [
    {
      "lat": 43.56,
      "lon": -79.56
    },
    {
      "lat": 49.56,
      "lon": -59.56
    }
  ]
}
# "place_type":["no"] 在传入的指定分类中查询
# {"context":"monely","boost":2}  boost增加权重返回结果会排在前面
POST /product_suggest/_search
{
  "suggest": {
    "tag_suggest": {
      "prefix": "he",
      "completion": {
        "field": "suggest",
        "size":10,
        "skip_duplicates":true,
        "contexts":{
          "place_type":[
            {"context":"no"},
            {"context":"monely","boost":2}
            ]
        }
      }
    }
  }
}
#地理位置查询
POST /product_suggest/_search
{
  "suggest": {
    "tag_suggest": {
      "prefix": "tre",
      "completion": {
        "field": "suggest",
        "size": 10,
        "skip_duplicates": true,
        "contexts": {
          "localtion": [
            {
              "lat": 43.55,
              "lon": -79.55
            }
          ]
        }
      }
    }
  }
}
相关推荐
INFINI Labs5 小时前
INFINI Console 纳管 Elasticsearch 9(一):指标监控、数据管理、DSL 语句执行
大数据·elasticsearch·搜索引擎·console
TracyCoder1237 小时前
ElasticSearch深入解析(十一):分页
大数据·elasticsearch·搜索引擎
Aric_Jones15 小时前
lua入门语法,包含安装,注释,变量,循环等
java·开发语言·git·elasticsearch·junit·lua
Kakaxiii1 天前
【2025最新】gitee+pycharm完成项目的上传与管理
elasticsearch·pycharm·gitee
不学会Ⅳ2 天前
【吃透 Elasticsearch 的核心原理】学习步骤
大数据·学习·elasticsearch
完美世界的一天2 天前
ES面试题系列「一」
大数据·elasticsearch·搜索引擎·面试·全文检索
好吃的肘子2 天前
ElasticSearch入门详解
java·大数据·elasticsearch·搜索引擎·云原生
极小狐2 天前
如何从极狐GitLab 容器镜像库中删除容器镜像?
java·linux·开发语言·数据库·python·elasticsearch·gitlab
A-花开堪折3 天前
RK3568-OpenHarmony(1) : OpenHarmony 5.1的编译
大数据·elasticsearch·搜索引擎
斯普信专业组3 天前
Elasticsearch内存管理与JVM优化:原理剖析与最佳实践
大数据·jvm·elasticsearch