Elasticsearch 之(51) Java API 基于bool 对汽车品牌进行多种条件的组合搜索
多种条件组合查询,其实就要用到我们之前《 Elasticsearch 之(5)kibana多种搜索方式》中讲解的es bool api。
package com.es.app; import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.client.transport.TransportClient; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.transport.InetSocketTransportAddress; import org.elasticsearch.index.query.QueryBuilder; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.search.SearchHit; import org.elasticsearch.transport.client.PreBuiltTransportClient; import java.net.InetAddress; public class BoolQuerySearchBrandApp { public static void main(String[] args) throws Exception { Settings settings = Settings.builder() .put("cluster.name", "elasticsearch") .put("client.transport.sniff", true) .build(); TransportClient client = new PreBuiltTransportClient(settings) .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300)); QueryBuilder queryBuilder = QueryBuilders.boolQuery() .must(QueryBuilders.matchQuery("brand", "宝马")) .mustNot(QueryBuilders.termQuery("name.raw", "宝马318")) .should(QueryBuilders.rangeQuery("produce_date").gte("2017-01-01").lte("2017-01-31")) .filter(QueryBuilders.rangeQuery("price").gte(280000).lte(350000)); SearchResponse searchResponse = client.prepareSearch("car_shop") .setTypes("cars") .setQuery(queryBuilder) .get(); for(SearchHit searchHit : searchResponse.getHits().getHits()) { System.out.println(searchHit.getSourceAsString()); } client.close(); } }
{ "brand": "宝马", "name": "宝马320", "price": 320000, "produce_date": "2017-01-01", "sale_price": 280000, "sale_date": "2017-01-25" } { "brand": "宝马", "name": "宝马310", "price": 320000, "produce_date": "2017-01-01", "sale_price": 280000, "sale_date": "2017-01-25" } { "brand": "宝马", "name": "宝马330", "price": 320000, "produce_date": "2017-01-01", "sale_price": 280000, "sale_date": "2017-01-25" }