ElasticSearch(8)--使用Java客户端进行复杂查询

进行复杂的查询:

包括:字段匹配查询、相似度查询、范围查询、组合查询、查询加排序

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", SortOrder.DESC)
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    // 组合查询
    @Test
    public void boolQuery(){
        SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
                .setQuery(QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("id", 3))
                        .must(QueryBuilders.matchQuery("title", "超薄")))
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    // 范围查询:可以查询数值也可以查询字符串
    @Test
    public void rangeQuery(){
        SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
                .setQuery(QueryBuilders.rangeQuery("id").from(1).to(3).includeLower(false))
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    // 相似度查询
    @Test
    public void fuzzyQuery(){
        SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
                .setQuery(QueryBuilders.fuzzyQuery("title", "appla"))
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    // 字段匹配查询,多个字段(会进行分词然后查询)
    @Test
    public void multiMatchQuery(){
        SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
                .setQuery(QueryBuilders.multiMatchQuery("手机", "title", "id"))
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    // 字段匹配查询,单个字段(会进行分词然后查询)
    @Test
    public void matchQuery(){
        SearchResponse searchResponse = this.client.prepareSearch(INDEX).setTypes(TYPE)
                .setQuery(QueryBuilders.matchQuery("title", "电视机"))
                .get();
        
        // 查询的总数(命中数)
        SearchHits hits = searchResponse.getHits();
        long totalHits = hits.getTotalHits();
        System.out.println("总记录数: " + totalHits);
        // 遍历查询的结果
        Iterator<SearchHit> iterator = hits.iterator();
        while (iterator.hasNext()){
            SearchHit next = iterator.next();
            // System.out.println(next.getSourceAsString());
            String id = next.getId();
            Map<String, Object> source = next.getSource();
            Integer productId = (Integer) source.get("id");
            String productTitle = (String) source.get("title");
            
            System.out.println("Document ID: " + id);
            System.out.println("商品的id: " + productId);
            System.out.println("商品的title: " + productTitle);
        }
    }
    
    // 获取客户端
    @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();
        }
    }
}
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个连接到远程 Elasticsearch 8.7.0 并使用 Java 客户端进行操作的示例代码: ```java import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.client.indices.CreateIndexRequest; import org.elasticsearch.client.indices.CreateIndexResponse; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentType; import java.io.IOException; public class ElasticsearchDemo { public static void main(String[] args) throws IOException { // 创建一个 Elasticsearch 高级客户端 RestHighLevelClient client = new RestHighLevelClient( RestClient.builder("localhost:9200") ); // 创建一个索引 CreateIndexRequest request = new CreateIndexRequest("my_index"); request.settings(Settings.builder() .put("index.number_of_shards", 1) .put("index.number_of_replicas", 1) ); XContentBuilder mappingBuilder = XContentFactory.jsonBuilder(); mappingBuilder.startObject(); { mappingBuilder.startObject("properties"); { mappingBuilder.startObject("title"); { mappingBuilder.field("type", "text"); } mappingBuilder.endObject(); mappingBuilder.startObject("content"); { mappingBuilder.field("type", "text"); } mappingBuilder.endObject(); } mappingBuilder.endObject(); } mappingBuilder.endObject(); request.mapping(mappingBuilder); CreateIndexResponse response = client.indices().create(request); // 关闭客户端连接 client.close(); } } ``` 以上代码中,我们首先创建一个 Elasticsearch 高级客户端,然后使用客户端创建一个名为"my_index"的索引,并为该索引设置了1个主分片和1个副本分片,同时定义了该索引中的两个字段"title"和"content"的类型为"text"。最后,我们关闭客户端连接。 当然,以上示例代码只是一个简单的示例,实际应用中可能需要根据具体需求进行复杂的操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值