ElasticSearch(4)--使用Java客戶端更新文檔

使用java客戶端更新文檔

package com.es.demo;

import java.net.InetAddress;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ExecutionException;

import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.action.update.UpdateResponse;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.index.get.GetResult;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import com.fasterxml.jackson.databind.ObjectMapper;

/**
 * 更新文檔
 * 
 * @author Beck
 * @date 2018年2月6日
 */
public class TestES3 {
	private static final String HOST = "127.0.0.1";
	private static final int PORT = 9300;
	
	private static final ObjectMapper MAPPER = new ObjectMapper();
	private TransportClient client = null;
	
	// 跟下文檔
	@Test
	public void updateDocument() throws InterruptedException, ExecutionException{
		UpdateRequest request = new UpdateRequest("eshop", "product", "AWFlwM2XrUhLs_HfwSw1");
		Map<String, Object> source = new HashMap<String,Object>();
		source.put("name", "APPLE手機2");
		source.put("price", 10999);
		request.doc(source);
		
		UpdateResponse response = this.client.update(request ).get();
		System.out.println(response.getVersion());
	}
	
	// 獲取客戶端
	@Before
	public void getClient() throws Exception{
		client = TransportClient.builder()
		.build()
		.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(HOST), PORT));
	}
	
	// 關閉客戶端
	@After
	public void closeClient(){
		if (this.client != null){
			this.client.close();
		}
	}
}
修改結果:



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章