进行复杂的查询:
包括:字段匹配查询、相似度查询、范围查询、组合查询、查询加排序
package com.es.querydemo;
import java.net.InetAddress;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.elasticsearch.action.admin.indices.mapping.put.PutMappingRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.Requests;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.sort.SortOrder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import com.es.bean.Product;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
/**
* 查询
*
* @author Beck
* @date 2018年2月6日
*/
public class TestESQuery2 {
private static final String HOST = "127.0.0.1";
private static final int PORT = 9300;
private static final String INDEX = "eshop";
private static final String TYPE = "product";
private static final ObjectMapper MAPPER = new ObjectMapper();
private TransportClient client = null;
// 查询加排序
@Test
public void SortOrder(){
SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
.setQuery(QueryBuilders.matchAllQuery())
.addSort("id", Sort