RestHighLevelClient批量删除满足某些条件的数据

这个可以通过DeleteByQueryRequest来实现,实例代码如下

	/**
	 * 批量删除文档
	 * @throws IOException
	 */
	@Test
	public void deleteByQueryRequest() throws IOException {
		DeleteByQueryRequest request = new DeleteByQueryRequest("sub_bank1031");
		request.setDocTypes("sub_bank");
		request.setQuery(new TermQueryBuilder("unionNumber", "104663451012"));
		request.setSize(1);
		BulkByScrollResponse resp = highLevelClient.deleteByQuery(request, RequestOptions.DEFAULT);
		println(resp);
	}

 

pom文件es相关依赖如下:

         <dependency>
            <groupId>org.elasticsearch</groupId>
            <artifactId>elasticsearch</artifactId>
            <version>6.8.0</version>
        </dependency>
        <!-- elasticsearch high level -->    
        <dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>elasticsearch-rest-high-level-client</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.elasticsearch</groupId>
                    <artifactId>elasticsearch</artifactId>                
                </exclusion>
            </exclusions>
            <version>6.8.0</version>
        </dependency>

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
要使用RestHighLevelClient批量添加数据,您可以使用BulkRequest来执行批量操作。首先,您需要创建一个BulkRequest对象,并为每个要添加的文档创建一个IndexRequest对象。然后,将每个IndexRequest对象添加到BulkRequest中。最后,通过调用RestHighLevelClient的bulk()方法执行批量操作。以下是一个示例代码: ``` BulkRequest bulkRequest = new BulkRequest(); bulkRequest.add(new IndexRequest(index, type, "1").source(jsonSource)); bulkRequest.add(new IndexRequest(index, type, "2").source(jsonSource)); bulkRequest.add(new IndexRequest(index, type, "3").source(jsonSource)); BulkResponse bulkResponse; try { bulkResponse = restHighLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT); } catch (IOException e) { e.printStackTrace(); } if (bulkResponse.hasFailures()) { // 处理出错的情况 } else { // 处理成功的情况 } ``` 在上面的代码中,jsonSource是一个包含要添加的文档数据的JSON字符串。您需要根据您的需求来替换index、type和jsonSource。bulkResponse是一个BulkResponse对象,您可以根据需要处理成功或失败的情况。 请注意,这只是一个示例代码,您需要根据您的实际需求来调整和修改。同时,您还需要确保您的RestHighLevelClient和相关的依赖库已正确配置和引入。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Elasticsearch Java REST Client 批量操作(Bulk API)](https://blog.csdn.net/wdz985721191/article/details/122920054)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值