Elasticsearch 搜索高亮功能及示例

在全文搜索中,高亮显示搜索关键字是一种常见的需求,它可以帮助用户快速定位到搜索词在文本中的位置。Elasticsearch 提供了强大的高亮功能,允许我们在搜索结果中突出显示匹配的文本片段。

高亮原理

Elasticsearch 的高亮功能通过在搜索结果中将关键字用特定的 HTML 标签标记出来实现。然后在前端页面中,可以给这些标签添加 CSS 样式,使其突出显示。

高亮语法

在 Elasticsearch 查询中,可以通过 highlight 参数来指定高亮的字段和一些高亮选项。基本语法如下:

json 复制代码
GET /index/_search
{
  "query": {
    "match": {
      "FIELD": "SEARCH_TERM"
    }
  },
  "highlight": {
    "fields": {
      "FIELD": {
        "pre_tags": ["<em>"],  // 标记高亮字段的前置标签
        "post_tags": ["</em>"]  // 标记高亮字段的后置标签
      }
    }
  }
}

高亮字段与搜索字段重合示例

当高亮字段与搜索字段一致时,即我们希望在搜索的字段上直接进行高亮显示。

示例

假设我们有一个 hotel 索引,其中 description 字段包含了酒店的描述信息,我们希望在搜索时高亮显示 description 字段中的关键字 "spa"。

json 复制代码
GET /hotel/_search
{
  "query": {
    "match": {
      "description": "spa"
    }
  },
  "highlight": {
    "fields": {
      "description": {
        "pre_tags": ["<em>"],
        "post_tags": ["</em>"]
      }
    }
  }
}

高亮字段与搜索字段不重合示例

当高亮字段与搜索字段不一致时,即我们希望在搜索的字段上进行高亮显示,但是高亮的字段是另一个字段。

示例

假设我们希望在 hotel 索引中搜索 name 字段中的 "如家",但是我们想在 description 字段上进行高亮显示。

json 复制代码
GET /hotel/_search
{
  "query": {
    "match": {
      "name": "如家"
    }
  },
  "highlight": {
    "fields": {
      "description": {
        "pre_tags": ["<em>"],
        "post_tags": ["</em>"],
        "require_field_match": false  // 允许高亮非搜索字段
      }
    }
  }
}

在这个例子中,我们使用了 require_field_match 设置为 false,这样即使 description 字段不是搜索字段,我们也可以在其上进行高亮显示。

结语

Elasticsearch 的搜索高亮功能极大地增强了搜索结果的可读性,帮助用户快速识别信息。通过合理配置高亮参数,我们可以在不同的字段上实现高亮效果,无论是在搜索字段上直接高亮,还是在其他字段上间接高亮。希望本文能帮助你更好地理解和使用 Elasticsearch 的搜索高亮功能。

相关推荐
Me4神秘4 小时前
国家级互联网骨干直联点及容量、互联网交换中心
大数据·信息与通信
zandy10116 小时前
全链路可控+极致性能,衡石HENGSHI CLI重新定义企业级BI工具的AI协作能力
大数据·人工智能·ai analytics·ai native·agent-first
ShawnLiaoking6 小时前
pycharm 上传更新代码
ide·elasticsearch·pycharm
果粒蹬i8 小时前
Elasticsearch 单机部署实测:安装流程、常见坑点与远程访问配置
大数据·elasticsearch·搜索引擎
AC赳赳老秦8 小时前
OpenClaw数据库高效操作指南:MySQL/PostgreSQL批量处理与数据迁移实战
大数据·数据库·mysql·elasticsearch·postgresql·deepseek·openclaw
小王毕业啦8 小时前
2006-2023年 省级-建成区绿化覆盖率数据(xlsx)
大数据·人工智能·数据挖掘·数据分析·社科数据·实证分析·经管数据
AEIC学术交流中心10 小时前
【快速EI检索 | SPIE出版】第六届中国膜计算论坛暨2026年人工智能、大数据与电气自动化国际学术会议(CWMC&AIBDE 2026)
大数据·人工智能·量子计算
历程里程碑10 小时前
二叉树---二叉树的中序遍历
java·大数据·开发语言·elasticsearch·链表·搜索引擎·lua
AC赳赳老秦10 小时前
OpenClaw text-translate技能:多语言批量翻译,解决跨境工作沟通难题
大数据·运维·数据库·人工智能·python·deepseek·openclaw
Elastic 中国社区官方博客11 小时前
使用 Elasticsearch + Jina embeddings 进行无监督文档聚类
大数据·人工智能·elasticsearch·搜索引擎·全文检索·jina