当前位置: 首页 > news >正文

ES高级用法:DeleteByQueryRequest

背景

在Elasticsearch中,delete_by_query API 允许你基于查询条件删除文档。在Java中,你可以使用Elasticsearch的Rest High Level Client或者Transport Client来执行这个操作。

示例代码

下面是使用Rest High Level Client进行delete_by_query操作的一个示例代码。

首先,你需要添加Elasticsearch的依赖到你的项目中。如果你使用Maven,可以添加如下依赖到你的pom.xml文件中:

<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId><version>7.10.1</version>
</dependency>

确保版本与你的Elasticsearch集群版本相匹配。

下面是使用Rest High Level Client执行delete_by_query操作的Java代码示例:

import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.reindex.BulkByScrollResponse;
import org.elasticsearch.index.reindex.DeleteByQueryRequest;import java.io.IOException;public class DeleteByQueryExample {public static void main(String[] args) throws IOException {// 创建Elasticsearch客户端try (RestHighLevelClient client = new RestHighLevelClient(RestClient.builder(new HttpHost("localhost", 9200, "http")))) {// 创建DeleteByQueryRequestDeleteByQueryRequest request = new DeleteByQueryRequest("your_index"); // 替换为你的索引名request.setQuery(QueryBuilders.matchQuery("field", "value")); // 替换为你的查询条件// 执行delete_by_query操作BulkByScrollResponse response = client.deleteByQuery(request, RequestOptions.DEFAULT);// 输出结果System.out.println("Deleted documents: " + response.getDeleted());} catch (Exception e) {e.printStackTrace();}}
}

在上面的代码中,我们首先创建了一个RestHighLevelClient实例用于与Elasticsearch集群通信。接着,我们构建了一个DeleteByQueryRequest对象,并设置了索引名和查询条件。然后,我们调用client.deleteByQuery方法来执行删除操作,并通过BulkByScrollResponse对象获取操作结果。

请注意,你需要根据你的具体需求替换your_index和查询条件。另外,HttpHost的参数应该与你的Elasticsearch集群配置相匹配。

在使用之前,请确保你的Elasticsearch集群版本与客户端库版本兼容,并且你已经正确配置了Elasticsearch的连接信息。

设置更新结果对搜索可见

为了确保delete_by_query操作后的结果能够立即对搜索可见,你可以设置RefreshPolicy为IMMEDIATE。这将导致操作完成后立即刷新索引。以下是在上面示例代码的基础上设置RefreshPolicy的方法:

import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.action.support.WriteRequest;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.reindex.BulkByScrollResponse;
import org.elasticsearch.index.reindex.DeleteByQueryRequest;
import org.apache.http.HttpHost;import java.io.IOException;public class DeleteByQueryExample {public static void main(String[] args) throws IOException {// 创建Elasticsearch客户端try (RestHighLevelClient client = new RestHighLevelClient(RestClient.builder(new HttpHost("localhost", 9200, "http")))) {// 创建DeleteByQueryRequestDeleteByQueryRequest request = new DeleteByQueryRequest("your_index"); // 替换为你的索引名request.setQuery(QueryBuilders.matchQuery("field", "value")); // 替换为你的查询条件// 设置RefreshPolicy为IMMEDIATErequest.setRefresh(true); // 这是简写方式// 或者更明确地使用下面的方法// request.setRefreshPolicy(WriteRequest.RefreshPolicy.IMMEDIATE);// 执行delete_by_query操作BulkByScrollResponse response = client.deleteByQuery(request, RequestOptions.DEFAULT);// 输出结果System.out.println("Deleted documents: " + response.getDeleted());} catch (Exception e) {e.printStackTrace();}}
}

在DeleteByQueryRequest对象上调用setRefresh(true)或setRefreshPolicy(WriteRequest.RefreshPolicy.IMMEDIATE)会将刷新策略设置为立即刷新。这意味着一旦delete_by_query操作完成,Elasticsearch会立即刷新相关的分片,使得删除的结果可以立即被搜索到。

请注意,频繁地使用IMMEDIATE刷新策略可能会对性能产生负面影响,因为每次刷新都是一个相对昂贵的操作。因此,它应该谨慎使用,特别是在高吞吐量的生产环境中。

结尾

  • 希望以上示例代码能够帮助你在Java中使用Elasticsearch的Rest High Level Client执行delete_by_query操作。
  • 另外,谨慎使用立即刷新策略,特别是在高吞吐量的生产环境中。

祝你在使用Elasticsearch时顺利无阻!

http://www.lryc.cn/news/274664.html

相关文章:

  • 使用docker build构建image
  • 【亲测有效】Win11 卸载MySQL5.7以及安装MySQL8.0.35
  • Beauty algorithm(三)腮红
  • DNS安全与访问控制
  • 【LMM 011】MiniGPT-5:通过 Generative Vokens 进行交错视觉语言生成的多模态大模型
  • WEB 3D技术 three.js 顶点交换
  • ROS学习笔记(11)进一步深入了解ROS第五步
  • 性能优化-OpenMP基础教程(四)-Android上运行OpenMP
  • 【转载】-财报-丈母娘教咱看财报(资产负债表-利润表-现金流量表)
  • HTML5大作业-精致版个人博客空间模板源码
  • 数字IC后端设计实现之Innovus update_names和changeInstName的各种应用场景
  • 1月6日,每日信息差
  • 部署上传漏洞的靶场环境upload-labs
  • Linux的压缩与解压
  • 互联网大厂面试题目
  • 单文件上传
  • 美经济学家预测,明年美股或将大跌86%,你怎么看?
  • 【BIAI】lecture 3 - GD BP CNN Hands-on
  • 计算机Java项目|基于SpringBoot+Vue的图书个性化推荐系统
  • lenovo联想小新Pro-13 2020 Intel IML版笔记本电脑(82DN)原装出厂Win10系统镜像
  • 54、Softmax 分类器以及它的底层原理
  • 【React】class组件生命周期函数的梳理和总结(第一篇)
  • [每周一更]-(第49期):一名成熟Go开发需储备的知识点(答案篇)- 2
  • 23种设计模式Python版
  • 2024年汉字小达人区级选拔备考——真题做一做:诗词连线
  • Vite scss 如何引入本地 字体
  • 扩展 apiserver 连接认证 ip, apiserver证书更新
  • VUE--保留小数(过滤器)
  • 书生·浦语大模型实战营第一次课堂笔记
  • Mysql为什么只能支持2000w左右的数据量?