ElasticSearch查询指南:从青铜到王者的骚操作

ElasticSearch查询指南:从青铜到王者的骚操作

本文来源于笔者的CSDN原创,由于掘金>已经去掉了转载功能,所以只好重新上传,以下图片依然保持最初发布的水印(如CSDN水印)。(以后属于本人原创均以新建状态在多个平台分享发布)

第一章 倒排索引:ES的"新华字典"制作指南

1.1 反向操作的艺术

想象你有一本菜谱,但目录是按食材排列的:

  • 🥚鸡蛋 → [番茄炒蛋 P12, 蛋花汤 P45]
  • 🍅番茄 → [番茄炒蛋 P12, 罗宋汤 P33]

索引实战三部曲

PUT /cookbook/_doc/1
{
  "title": "深夜食堂之黯然销魂饭",
  "ingredients": ["叉烧", "温泉蛋", "葱花"],
  "steps": "将叉烧切成..." 
}

GET /cookbook/_search
{
  "query": {
    "match": { "ingredients": "温泉蛋 叉烧" }
  }
}

第二章 DSL语法:搜索界的乐高积木

2.1 万能bool查询:相亲条件排列组合

{
  "query": {
    "bool": {
      "must": [   // 必须满足
        { "term": { "gender": "女" } },
        { "range": { "age": { "gte": 25 } } }
      ],
      "should": [  // 满足更好
        { "term": { "hasPet": "布偶猫" } },
        { "match": { "hobby": "滑雪 潜水" } }
      ],
      "must_not": { // 绝对不要
        "term": { "character": "妈宝男" }
      },
      "filter": [  // 精确筛选
        { "geo_distance": { "distance": "10km", "location": "陆家嘴" } }
      ]
    }
  }
}

2.2 查询全家桶套餐

查询类型使用场景相当于相亲中的…
term精准匹配“必须本地户口!”
match语义分析“三观合得来就行”
match_phrase词组匹配“要求’上海交大毕业’”
range范围筛选“身高175cm以上”

第三章 高阶操作:搜索结果的精装修

3.1 分页的陷阱与救赎

// 基础分页(小数据量适用)
{
  "from": 100,
  "size": 10,
  "query": { "match_all": {} }
}

// 深度分页正确姿势
{
  "size": 10,
  "sort": [
    { "timestamp": "desc" },
    { "_id": "asc" }
  ],
  "search_after": [1625000000, "abc123"]
}

3.2 排序的七十二变

// 多维度排序示例
{
  "sort": [
    { "price": { "order": "asc" } },  // 优先便宜货
    { "sales": { "order": "desc" } },  // 其次销量王
    { "_score": { "order": "desc" } } // 最后匹配度
  ]
}

第四章 实战演练:电商搜索系统改造记

4.1 索引定义:给商品打标签

PUT /ecommerce
{
  "mappings": {
    "properties": {
      "title": {
        "type": "text",
        "analyzer": "ik_max_word",
        "fields": {
          "keyword": { "type": "keyword" }
        }
      },
      "price": { "type": "double" },
      "category": { "type": "keyword" },
      "tags": { "type": "nested" }
    }
  }
}

4.2 综合查询:找性价比之王

GET /ecommerce/_search
{
  "query": {
    "bool": {
      "must": [
        { "match": { "title": "无线耳机" } }
      ],
      "filter": [
        { "range": { "price": { "gte": 199, "lte": 599 } } },
        { "term": { "category": "数码配件" } }
      ],
      "should": [
        { "term": { "tags": "七天无理由退货" } },
        { "term": { "tags": "旗舰店" } }
      ]
    }
  },
  "sort": [
    { "rating": { "order": "desc" } },
    { "price": { "order": "asc" } }
  ],
  "from": 0,
  "size": 20
}

结果分析技巧

{
  "took": 48,             // 查询耗时48ms
  "hits": {
    "total": { "value": 82 },  // 共82件商品符合
    "max_score": null,
    "hits": [
      {
        "_score": 12.345,
        "_source": {
          "title": "【旗舰店】Beats无线降噪耳机",
          "price": 499.00,
          "rating": 4.8
        },
        "sort": [4.8, 499.0]  // 排序字段值
      }
    ]
  }
}

第五章 避坑宝典:来自ES老司机的忠告

5.1 中文分词惨案现场

错误示范:

{ "term": { "title": "小米手机" } } // 永远搜不到!

正确姿势:

{ "match": { "title": "小米手机" } } // 自动分词搜索

// 精确匹配需用keyword
{ "term": { "title.keyword": "小米手机" } }

5.2 性能优化三板斧

  1. 索引设计防脱发
PUT /logs-2023-08
{
  "settings": {
    "number_of_shards": 3,
    "number_of_replicas": 1
  }
}
  1. 批量操作保平安
# 错误示范:循环单条插入
for data in dataset:
    es.index(data)

# 正确姿势:批量操作
from elasticsearch.helpers import bulk
bulk(es, ({"_index":"logs","_source":data} for data in dataset))
  1. 冷热数据分离术
Hot节点(NVMe SSD) ←→ Warm节点(SATA SSD) ←→ Cold节点(HDD归档)

ES生存法则
遇到性能问题先看日志,再看内存,最后默念三遍"分片设置合理吗?"
查询DSL就像搭积木,多摔几次就熟练了~
记住:永远不要在凌晨3点修改生产环境的Mapping!😱

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/975813.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【废物研究生零基础刷算法】DFS与递归(一)典型题型

文章目录 跳台阶递归实现指数级枚举递归实现排列型枚举上面两题总结 递归实现组合型枚举P1036选数 跳台阶 思路: 如果 n 1,只有一种走法(走 1 级)。如果 n 2,有两种走法(11 或 2)。对于 n &g…

Java-01-源码篇-04集合-05-ConcurrentHashMap(1)

1.1 加载因子 加载因子(Load Factor)是用来决定什么时候需要扩容的一个参数。具体来说,加载因子 当前元素数量 / 桶的数量,当某个桶的元素个数超过了 桶的数量 加载因子 时,就会触发扩容。 我们都知道 ConcurrentHas…

AI赋能的未来城市:如何用智能化提升生活质量?

这会是我们憧憬的未来城市吗? 随着技术的不断进步和城市化进程的加速,现代城市面临着诸多挑战——交通拥堵、环境污染、能源消耗、人口老龄化等问题愈发突出。为了应对这些挑战,建设智慧城市已成为全球发展的重要趋势。在这一进程中&#xf…

DeepSeek各模型现有版本对比分析

文章目录 一、基础模型系列:V1 到 V3 的演进二、专用模型系列:推理与多模态三、版本选型与商业化趋势 DeepSeek作为最近特别火爆的模型,本文将对DeepSeek现有的主要版本进行对比分析,涵盖参数规模、训练数据、功能改进、应用场景和性能表现等…

【亲测有效】百度Ueditor富文本编辑器添加插入视频、视频不显示、和插入视频后二次编辑视频标签不显示,显示成img标签,二次保存视频被替换问题,解决方案

【亲测有效】项目使用百度Ueditor富文本编辑器上传视频相关操作问题 1.百度Ueditor富文本编辑器添加插入视频、视频不显示 2.百度Ueditor富文本编辑器插入视频后二次编辑视频标签不显示,在编辑器内显示成img标签,二次保存视频被替换问题 问题1&#xff1…

hot100_108. 将有序数组转换为二叉搜索树

hot100_108. 将有序数组转换为二叉搜索树 思路 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。 示例 1: 输入:nums [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释&#…

RFID涉密载体柜:智能安全,全程守护,提供智能化的安全管控

行业背景 RFID智能载体柜(DW-G101)是一种便捷化的载体管控系统,它采用RFID技术实现信息化,可以大大提高载体管理的效率和准确性。 随着信息化的快速发展,涉密载体(如文件、U盘、光盘等)的管理…

【复习】计算机网络

网络模型 OSI 应用层:给应用程序提供统一的接口表示层:把数据转换成兼容另一个系统能识别的格式会话层:负责建立、管理、终止表示层实体之间的通信会话传输层:负责端到端的数据传输网络层:负责数据的路由、转发、分片…

多线程篇学习面试

多线程 1.乐观锁、CAS思想 java乐观锁机制: ​ 乐观锁体现的是悲观锁的反面。它是一种积极的思想,它总是认为数据是不会被修改的,所以是不会对数据上锁的。但是乐观锁在更新的时候会去判断数据是否被更新过。乐观锁的实现方案一般有两种&a…

Spring Boot 概要(官网文档解读)

Spring Boot 概述 Spring Boot 是一个高效构建 Spring 生产级应用的脚手架工具,它简化了基于 Spring 框架的开发过程。 Spring Boot 也是一个“构件组装门户”,何为构件组装门户呢?所谓的“构件组装门户”指的是一个对外提供的Web平台&#x…

计算机毕业设计SpringBoot+Vue.jst0甘肃非物质文化网站(源码+LW文档+PPT+讲解)

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

匹配算法:向下就近原则,向下没有就向上

匹配算法&#xff1a;向下就近原则&#xff0c;向下没有就向上 实现方式一实现方式二总结 实现方式一 private static List<Integer> findMatches(List<Integer> sourceList, List<Integer> searchValues) {List<Integer> sortedList sourceList.stre…

ESP32S3:解决RWDT无法触发中断问题,二次开发者怎么才能使用内部RTC看门狗中断RWDT呢?

目录 基于ESP32S3:解决RWDT无法触发中断问题引言解决方案1. 查看报错日志2. 分析报错及一步一步找到解决方法3.小结我的源码基于ESP32S3:解决RWDT无法触发中断问题 引言 在嵌入式系统中,RWDT(看门狗定时器)是确保系统稳定性的重要组件。然而,在某些情况下,RWDT可能无法…

【GPU驱动】OpenGLES图形管线渲染机制

OpenGLES图形管线渲染机制 OpenGL/ES 的渲染管线也是一个典型的图形流水线&#xff08;Graphics Pipeline&#xff09;&#xff0c;包括多个阶段&#xff0c;每个阶段都负责对图形数据进行处理。管线的核心目标是将图形数据转换为最终的图像&#xff0c;这些图像可以显示在屏幕…

PHP post 数据丢失问题

max_input_vars是PHP配置选项之一&#xff0c;用于设置一个请求中允许的最大输入变量数。它指定了在处理POST请求或者通过URL传递的参数时&#xff0c;PHP脚本能够接收和处理的最大变量数量。 max_input_vars的默认值是1000&#xff0c;意味着一个请求中最多可以包含1000个输入…

Mac下Python版本管理,适用于pyenv不起作用的情况

前言 声明&#xff1a;之前也在网上看到过可以使用pyenv来管理python版本&#xff0c;但由于作者的python安装路径实在是繁杂不堪&#xff0c;因此安装完成pyenv体验下来没有任何用处&#xff0c;但偶然发现vscode似乎可以看到各个python版本&#xff0c;因此写下这篇博客记录…

什么是完全前向保密(PFS)?

在当今数字化时代&#xff0c;信息安全至关重要。而密码学中的完全前向保密&#xff08;Perfect Forward Secrecy&#xff0c;简称PFS&#xff09;技术&#xff0c;已经成为保障信息安全的关键一环。如果没有完全前向保密&#xff0c;一旦长期密钥被泄露&#xff0c;攻击者就可…

计算机毕业设计SpringBoot+Vue.jst在线文档管理系统(源码+LW文档+PPT+讲解)

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…

Vulnhun靶机-kioptix level 4-sql注入万能密码拿到权限ssh连接利用mysql-udf漏洞提权

目录 一、环境搭建信息收集扫描ip扫描开放端口扫描版本服务信息指纹探测目录扫描 二、Web渗透sql注入 三、提权UDF提权修改权限 一、环境搭建 然后选择靶机所在文件夹 信息收集 本靶机ip和攻击机ip 攻击机&#xff1a;192.168.108.130 靶机&#xff1a;192.168.108.141 扫描…

【NLP 31、预训练模型的发展过程】

人的行为&#xff0c;究竟是人所带来的思维方式不同还是与机器一样&#xff0c;刻在脑海里的公式呢&#xff1f; 只是因为不同的人公式不同&#xff0c;所以人的行为才不同&#xff0c;可这又真的是人引以为傲的意识吗&#xff1f; 人脑只是相当于一个大型、驳杂的处理器&#…