elasticsearch Insert 插入数据和delete 删除数据(Java),
首先我不赞成再采用一些中间件(jar包)来解决和 Elasticsearch 之间的交互,比如 Spring-data-elasticsearch.jar 系列一样,用就得依赖它。而 Elasticsearch
本身的用法就是很简洁的,也很容易,只要稍微加一下封装,即可解决。下面上我的简单封装的批量处理。
package com.sojson.core.elasticsearch.manager;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import net.sf.json.JSONObject;import org.elasticsearch.action.bulk.BulkRequestBuilder;import org.elasticsearch.action.bulk.BulkResponse;import org.elasticsearch.action.index.IndexRequestBuilder;import com.sojson.common.utils.StringUtils;import com.sojson.core.elasticsearch.utils.ESTools;public class InsertManager {/*** 添加数据到Elasticsearch* @param index 索引* @param type 类型* @param idName Id字段名称* @param json 存储的JSON,可以接受Map* @return*/public static Map save(String index, String type, String idName,JSONObject json) {List list = new ArrayList();list.add(json);return save(index, type, idName, list);}/*** 添加数据到Elasticsearch* @param index 索引* @param type 类型* @param idName Id字段名称* @param listData 一个对象集合* @return*/("unchecked")public static Map save(String index, String type, String idName,List listData) {BulkRequestBuilder bulkRequest = ESTools.client.prepareBulk().setRefresh(true);Map resultMap = new HashMap();for (Object object : listData) {JSONObject json = JSONObject.fromObject(object);//没有指定idName 那就让Elasticsearch自动生成if(StringUtils.isBlank(idName)){IndexRequestBuilder lrb = ESTools.client .prepareIndex(index, type) .setSource(json);bulkRequest.add(lrb);}else{String idValue = json.optString(idName);IndexRequestBuilder lrb = ESTools.client .prepareIndex(index, type,idValue) .setSource(json);bulkRequest.add(lrb);}}BulkResponse bulkResponse = bulkRequest.execute().actionGet();if (bulkResponse.hasFailures()) {// process failures by iterating through each bulk response itemSystem.out.println(bulkResponse.getItems().toString());resultMap.put("500", "保存ES失败!");return resultMap;}bulkRequest = ESTools.client.prepareBulk();resultMap.put("200", "保存ES成功!");return resultMap;}}
DeleteByQuery的方式。今天就先介绍一个根据ID删除。上代码。package com.sojson.core.elasticsearch.manager;import org.elasticsearch.action.delete.DeleteResponse;import com.sojson.common.model.SOBanggKey;import com.sojson.core.elasticsearch.utils.ESTools;public class DeleteManager {/*** 根据ID删除* @param key* @return*/public static int deleteSOBanggByKey(SOBanggKey key) {//这里可以忽略,组装一个我业务逻辑的IDString prefix = "%sx_x%s";String id = String.format(prefix, key.getId(),key.getGid());DeleteResponse result = ESTools.client.prepareDelete().setRefresh(true).setIndex(MappingManager.INDEX).setType(MappingManager.B_TYPE).setId(id)//设置ID.setRefresh(true)//刷新.execute().actionGet();//是否查找并删除boolean isfound = result.isFound();return isfound?1:0;}}
本站文章为和通数据库网友分享或者投稿,欢迎任何形式的转载,但请务必注明出处.
同时文章内容如有侵犯了您的权益,请联系QQ:970679559,我们会在尽快处理。