Elasticsearch 综合搜索案例解析

Elasticsearch 是一个功能强大的搜索引擎,它不仅支持全文搜索,还提供了排序、分页、高亮显示等多种搜索结果处理功能。通过综合使用这些功能,我们可以构建出丰富而高效的搜索应用。本文将通过一个具体的案例,介绍如何在 Elasticsearch 中进行综合搜索。

综合搜索案例

假设我们正在开发一个酒店搜索应用,用户希望根据酒店名称进行搜索,并且希望结果按照价格升序排序,同时还能高亮显示搜索关键字,以及根据地理位置进行距离排序。

搜索需求

  • 搜索包含"如家"的酒店名称。
  • 结果按照价格升序排序。
  • 高亮显示搜索关键字"如家"。
  • 按照距离某个地理位置(例如,经纬度为 31.040699, 121.618075)的酒店进行距离升序排序。

Elasticsearch 查询

json 复制代码
GET /hotel/_search
{
  "query": {
    "match": {
      "name": "如家"
    }
  },
  "from": 0,  // 分页开始的位置
  "size": 20,  // 期望获取的文档总数
  "sort": [
    {
      "price": "asc"  // 普通排序,按价格升序
    },
    {
      "_geo_distance": {  // 距离排序
        "location": "31.040699,121.618075",
        "order": "asc",
        "unit": "km"
      }
    }
  ],
  "highlight": {
    "fields": {  // 高亮字段
      "name": {
        "pre_tags": ["<em>"],  // 用来标记高亮字段的前置标签
        "post_tags": ["</em>"]  // 用来标记高亮字段的后置标签
      }
    }
  }
}

查询解释

  1. 查询 (query): 使用 match 查询来搜索 name 字段中包含"如家"的文档。
  2. 分页 (fromsize): from 指定了结果的起始位置,size 指定了返回结果的数量。这里从第 0 个结果开始,返回 20 条结果。
  3. 排序 (sort): 包含两个排序条件,首先是按照 price 字段升序排序,其次是按照与指定地理位置的距离升序排序 (_geo_distance)。
  4. 高亮显示 (highlight): 指定了 name 字段的高亮显示,使用 <em> 标签包裹搜索关键字,以便在结果中突出显示。

结语

通过上述案例,我们可以看到 Elasticsearch 如何在一次查询中实现多种搜索结果处理功能的综合应用。这不仅提高了搜索结果的相关性,也增强了用户体验。理解并掌握这些功能,可以帮助我们在开发搜索应用时更加灵活和高效。希望本文能够帮助你更好地利用 Elasticsearch 的强大搜索能力。

相关推荐
千里码aicood7 小时前
计算机大数据、人工智能与智能系统开发定制开发
大数据·人工智能·深度学习·决策树·机器学习·森林树
非著名架构师9 小时前
城市通风廊道的科学依据:气候大数据如何指导未来城市规划设计
大数据·风光功率预测·高精度气象数据
IIIIIILLLLLLLLLLLLL9 小时前
Hadoop集群时间同步方法
大数据·hadoop·分布式
搞科研的小刘选手9 小时前
【经管专题会议】第五届大数据经济与数字化管理国际学术会议(BDEDM 2026)
大数据·区块链·学术会议·数据化管理·经济理论
蓝耘智算10 小时前
GPU算力租赁与算力云平台选型指南:从需求匹配到成本优化的实战思路
大数据·人工智能·ai·gpu算力·蓝耘
liliangcsdn10 小时前
如何用bootstrap模拟估计pass@k
大数据·人工智能·bootstrap
DMD16810 小时前
AI赋能旅游与酒店业:技术逻辑与开发实践解析
大数据·人工智能·信息可视化·重构·旅游·产业升级
Elastic 中国社区官方博客11 小时前
Elasticsearch 中使用 NVIDIA cuVS 实现最高快 12 倍的向量索引速度:GPU 加速第 2 章
大数据·人工智能·elasticsearch·搜索引擎·ai·全文检索·数据库架构
jqpwxt11 小时前
启点智慧景区多商户分账系统,多业态景区收银管理系统
大数据·旅游
jkyy201411 小时前
线上线下融合、跨场景协同—社区健康医疗小屋的智能升级
大数据·人工智能·物联网·健康医疗