ElasticSearch的DSL查询
ElasticSearch的DSL查询
准备工作
创建测试方法,初始化测试结构。
import org.apache.http.HttpHost;
import org.apache.lucene.search.TotalHits;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightField;
import org.elasticsearch.search.sort.SortOrder;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;import java.io.IOException;
import java.util.Map;public class DemoTest {private RestHighLevelClient client;/*** * 因为下面会重复使用输出语句所以就单独抽出来封装了** @param response 查询结果响应体*/public static void handelResponse(SearchResponse response) {// 查询的总数TotalHits total = response.getHits().getTotalHits();System.out.println("total===>" + total);SearchHits searchHits = response.getHits();// 输出查询结果searchHits.forEach(hit -> {// 查询时JSON数据,可以使用实体将其转换。String json = hit.getSourceAsString();System.out.println(json);// 高亮返回体Map<String, HighlightField> map = hit.getHighlightFields();if (map != null) {System.out.println("-----------------高亮显示---------------");HighlightField highlightField = map.get("name");System.out.println("name===>" + highlightField.getName());System.out.println("fragments===>" + highlightField.getFragments()[0]);}});}@BeforeEachvoid setup() {this.client = new RestHighLevelClient(RestClient.builder(HttpHost.create("http://192.168.3.98:9200")));}@AfterEachvoid teardown() throws IOException {this.client.close();}
}
DSL查询
普通查询全部
new SearchRequest("hotel")
查询索引库名称。
@Test
void testMatchAll() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询全部内容request.source().query(QueryBuilders.matchAllQuery());// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# 查询所有
GET /_search
{"query": {"match_all": {}}
}
match查询-单字段查询
// match查询-单字段查询
@Test
void testMatch() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容request.source().query(QueryBuilders.matchQuery("all", "如家"));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# match,根据单字段查询,推荐使用
GET /hotel/_search
{"query": {"match": {"all": "外滩如家"}}
}
match查询-多字段查询
@Test
void testMultiMatchQuery() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容request.source().query(QueryBuilders.multiMatchQuery("如家", "name", "business"));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# multi_match 多字段查询,不推荐,性能低
GET /hotel/_search
{"query": {"multi_match": {"query": "外滩如家","fields": ["name","brand","business"]}}
}
精确查询
@Test
void termQuery() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容-精确查找request.source().query(QueryBuilders.termQuery("city", "深圳"));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# 精确查找-term,不会分词
GET /hotel/_search
{"query": {"term": {"city": {"value": "上海"}}}
}
范围查找
@Test
void testRange() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容request.source().query(QueryBuilders.rangeQuery("price").gte(100).lt(150));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# range 范围查询
GET /hotel/_search
{"query": {"range": {"price": {"gte": 100,"lte": 300}}}
}
布尔查询
@Test
void testBoolean() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容BoolQueryBuilder query = QueryBuilders.boolQuery();query.must(QueryBuilders.termQuery("city", "杭州"));query.filter(QueryBuilders.rangeQuery("price").lt(250));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# 不等于gt,lt不等于
GET /hotel/_search
{"query": {"range": {"FIELD": {"gt": 10,"lt": 20}}}
}
排序、分页
@Test
void testFrom() throws IOException {// 页码,每页大小int page = 1, size = 5;// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容request.source().query(QueryBuilders.matchAllQuery());request.source().from((page - 1) * size).size(5);request.source().sort("price", SortOrder.ASC);// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
高亮
@Test
void testHighLighter() throws IOException {// 指定查询的索引库SearchRequest request = new SearchRequest("hotel");// 查询内容request.source().query(QueryBuilders.matchQuery("all", "如家"));request.source().highlighter(new HighlightBuilder().field("name").requireFieldMatch(false));// 得到查询返回体,传入返回体到封装的返回体输出SearchResponse response = client.search(request, RequestOptions.DEFAULT);handelResponse(response);
}
对应控制台。
# 搜索结果高亮显示,默认字段必须与高亮字段一致,默认是em标签
GET /hotel/_search
{"query": {"match": {"all": "如家"}},"highlight": {"fields": {"name": {"require_field_match": "false","pre_tags": "<i>","post_tags": "</i>"}}}, "from": 0,"size": 20
}
相关文章:
ElasticSearch的DSL查询
ElasticSearch的DSL查询 准备工作 创建测试方法,初始化测试结构。 import org.apache.http.HttpHost; import org.apache.lucene.search.TotalHits; import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchRespo…...
每天定时杀spark进程
##编写shell脚本 #!/bin/bash arr(“zhangsan” “lisi” “wangwu”) for i in “${arr[]}” do processps -ef|grep ${i}| grep -v "grep"| awk {print $2} kill -9 ${process} done ##每日定时杀手动启动的进程 0 19 * * * cd /kill_process && sh kil…...

win10 安装kubectl,配置config连接k8s集群
安装kubectl 按照官方文档安装:https://kubernetes.io/docs/tasks/tools/install-kubectl-windows/ curl安装 (1)下载curl安装压缩包: curl for Windows (2)配置环境变量: 用户变量: Path变…...

Calico IPIP和BGP TOR的数据包走向
IPIP Mesh全网互联 文字描述 APOD eth0 10.7.75.132 -----> APOD 网关 -----> A宿主机 cali76174826315网卡 -----> Atunl0 10.7.75.128 封装 ----> Aeth0 10.120.181.20 -----> 通过网关 10.120.181.254 -----> 下一跳 BNODE eth0 10.120.179.8 解封装 --…...
静态成员主要用于提供与类本身相关的功能或数据,有什么应用场景
静态成员(包括静态方法和静态属性)在JavaScript中常用于多种应用场景,它们为类提供了与类本身直接相关而不是与实例相关的功能或数据。以下是一些常见的应用场景: 工厂方法 静态方法可以作为工厂方法,用于创建类的实…...

在线考试|基于Springboot的在线考试管理系统设计与实现(源码+数据库+文档)
在线考试管理系统目录 目录 基于Springboot的在线考试管理系统设计与实现 一、前言 二、系统设计 三、系统功能设计 1、前台: 2、后台 管理员功能 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: 博主…...

C语言-----数据在内存中的存储(1)
1.整数在内存中的存储 我们之前就了解过整数的二进制写法分别有3种,分别为原码,反码,补码。整型在内存中存储的是补码。 原码,反码,补码都有自己的符号位和数值位,符号位为1时,则表示负数&…...

Ribbon有哪些负载均衡策略
负载均衡类都实现了IRule接口。 RandomRule:随机的选用一个实例 RoundRobinRule:轮询的使用实例 RetryRule:在轮询的基础上加了一个错误重试机制,在deadline时间内会不断的重试 WeightResponeTimeRule:根据权重去做…...
websocket多级nginx代理
在使用多层Nginx代理时,WebSocket的连接可能会遇到一些问题,因为WebSocket连接是持久化的,它需要Upgrade头部来确认升级到WebSocket协议。在多层代理的情况下,每层代理可能会修改或丢失这个Upgrade头部信息。 为了确保WebSocket能…...

【python从入门到精通】-- 第四战:语句汇总
🌈 个人主页:白子寰 🔥 分类专栏:python从入门到精通,魔法指针,进阶C,C语言,C语言题集,C语言实现游戏👈 希望得到您的订阅和支持~ 💡 坚持创作博文…...
【NC50937】货仓选址
题目 货仓选址 二分,前缀和,数学推导 思路 由题意可知货仓的位置是可以和商店的位置重合的。首先应该将商店的坐标从小到大排序,然后假设商店的坐标为 a i a_i ai,货仓的坐标为 x x x,货仓左侧第一家商店&#x…...
Nginx配置使用笔记
Nginx配置使用笔记 前言 官网下载压缩包https://nginx.org/ 解压完成后当前目录cmd输入nginx指令启动 访问http://localhost:80确认启动成功 1.部署前端项目 部署前端项目到路径E:\Workspaces\Vscode\app-web 2.0配置nginx.conf文件 在nginx安装的conf目录下新建一个文件夹l…...

GridLayoutManager 中的一些坑
前言 如果GridLayoutManager使用item的布局都是wrap_cotent 那么会在布局更改时会出现一些出人意料的情况。(本文完全不具备可读性和说教性,仅为博主方便查找问题) 布局item: <!--layout_item.xml--> <?xml version"1.0&qu…...

算法实验二 矩阵最小路径和 LIS
算法实验课二 矩阵最小路径和 leetcode裸题 最小路径和 给定一个包含非负整数的 *m* x *n* 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。 示例 1: 输入&…...

Apache Paimon实时数据糊介绍
Apache Paimon 是一种湖格式,可以使用 Flink 和 Spark 构建实时 数据糊 架构,用于流式和批处理操作。Paimon 创新地将湖格式和 LSM(日志结构合并树)结构相结合,将实时流式更新引入湖架构中。 Paimon 提供以下核心功能: 实时更新: 主键表支持大规模更新的写入,具有非常…...

计算机网络:数据链路层 - 可靠传输协议
计算机网络:数据链路层 - 可靠传输协议 可靠传输概念停止-等待协议 SW回退N帧协议 GBN选择重传协议 SR 可靠传输概念 如下所示,帧在传输过程中受到干扰,产生了误码。接收方的数据链路层,通过真伪中的真检验序列 FCS 字段的值&…...

苍穹外卖07(缓存菜品,SpringCache,缓存套餐,添加购物车菜品和套餐多下单,查看购物车,清除购物车,删除购物车中一个商品)
目录 一、缓存菜品 1 问题说明 2 实现思路 3 代码开发:修改DishServiceImpl 4 功能测试 二、SpringCache 1. 介绍 2. 使用语法 1 起步依赖 2 使用要求 3 常用注解 4 SpEL表达式(了解备用) 5 步骤小结 3.入门案例 1 准备环境 2 使用入门 1 引导类上加…...

C语言第三十八弹---编译和链接
✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】 编译和链接 1、翻译环境和运行环境 2、翻译环境 2.1、预处理(预编译) 2.2、编译 2.2.1、词法分析 2.2.2、语法分析 2.2.3、语义分…...

无人售货奶柜:开启便捷生活的新篇章
无人售货奶柜:开启便捷生活的新篇章 在这个快节奏的现代生活中,科技的革新不仅为我们带来了前所未有的便利,更在不经意间改变着我们的日常。其中,无人售货技术的出现,尤其是无人售货奶柜,已经成为我们生活…...
STM32为什么不能跑Linux?
STM32是一系列基于ARM Cortex-M微控制器的产品,它们主要用于嵌入式系统中。而Linux则是一个开源的类Unix操作系统,主要面向的是桌面电脑、服务器等资源丰富的计算机。虽然理论上可以将Linux移植到STM32上运行,但是由于两者之间存在着很多技术…...

大数据学习栈记——Neo4j的安装与使用
本文介绍图数据库Neofj的安装与使用,操作系统:Ubuntu24.04,Neofj版本:2025.04.0。 Apt安装 Neofj可以进行官网安装:Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...

【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
React Native在HarmonyOS 5.0阅读类应用开发中的实践
一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强,React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 (1)使用React Native…...

2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
文章目录 现象:mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时,可能是因为以下几个原因:1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...
JS设计模式(4):观察者模式
JS设计模式(4):观察者模式 一、引入 在开发中,我们经常会遇到这样的场景:一个对象的状态变化需要自动通知其他对象,比如: 电商平台中,商品库存变化时需要通知所有订阅该商品的用户;新闻网站中࿰…...