Elasticsearch——QueryBuilder简单查询

elasticsearch中存储的全部文档

1.matchAllQuery()

matchAllQuery()方法用来匹配全部文档

public class QueryTest {  
    public static void main(String[] args) {  
        //创建对象,设置集群名称和IP地址  
        ElasticsearchUtils es = new ElasticsearchUtils("im_shan",  
                "localhost");  
        String indexName = "school";//索引名称  
        String typeName = "student";//类型名称  
        //搜索全部文档  
        QueryBuilder queryBuilder = QueryBuilders.matchAllQuery();  
        SearchResponse searchResponse = es.searcher(indexName, typeName,  
            queryBuilder);  
        SearchHits hits = searchResponse.getHits();  
        SearchHit[] searchHits = hits.getHits();  
        int i = 0;  
        for (SearchHit searchHit : searchHits) {  
            String name = (String) searchHit.getSource().get("name");  
            String birth = (String) searchHit.getSource().get("birth");  
            String interest = (String) searchHit.getSource().get("interest");  
            System.out.println("-------------" + (++i) + "------------");  
            System.out.println(name);  
            System.out.println(birth);  
            System.out.println(interest);  
        }  
  
    }  
}

控制台将输出全部文档

输出:  
-------------1------------  
amy  
1995-11-10  
singing dancing  
-------------2------------  
angle  
1996-05-01  
singing reading  
-------------3------------  
jackson  
1995-08-01  
basketball music reading  
-------------4------------  
jack  
1995-03-21  
football music  
-------------5------------  
tom  
1995-09-11  
reading music

2.matchQuery(String name,Object  text)

matchQuery("filedname","value")匹配单个字段,匹配字段名为filedname,值为value的文档

java] view plain copy
//单个匹配,搜索name为jack的文档  
QueryBuilder queryBuilder = QueryBuilders.matchQuery("name", "jack");

此时会输出一条记录,因为只有一个name为jack的文档

-------------1------------  
jack  
1995-03-21  
football music 

3.multiMatchQuery(Object text, String... fieldNames)

多个字段匹配某一个值

[java] view plain copy 
QueryBuilder queryBuilder = QueryBuilders.multiMatchQuery("music",  
           "name", "interest");//搜索name中或interest中包含有music的文档(必须与music一致)

控制台输出如下

-------------1------------  
jack  
1995-03-21  
football music  
-------------2------------  
tom  
1995-09-11  
reading music  
-------------3------------  
jackson  
1995-08-01  
basketball music reading

4.wildcardQuery()模糊查询

模糊查询,?匹配单个字符,*匹配多个字符

WildcardQueryBuilder queryBuilder = QueryBuilders.wildcardQuery("name",  
            "*jack*");//搜索名字中含有jack文档(name中只要包含jack即可)  

控制台输出如下

-------------1------------  
jackson  
1995-08-01  
basketball music reading  
-------------2------------  
jack  
1995-03-21  
football music

5.使用BoolQueryBuilder进行复合查询
使用must

java] view plain copy
//模糊查询  
WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(  
            "name", "*jack*");//搜索名字中含有jack的文档  
WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(  
            "interest", "*read*");//搜索interest中含有read的文档    
BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();  
//name中必须含有jack,interest中必须含有read,相当于and  
boolQueryBuilder.must(queryBuilder1);  
boolQueryBuilder.must(queryBuilder2);

控制台输出如下(name中必须含有jack,interest中必须含有read,只有一条文档匹配):

-------------1------------  
jackson  
1995-08-01  
basketball music reading  

使用should

WildcardQueryBuilder queryBuilder1 = QueryBuilders.wildcardQuery(  
            "name", "*jack*");//搜索名字中含有jack的文档  
WildcardQueryBuilder queryBuilder2 = QueryBuilders.wildcardQuery(  
            "interest", "*read*");//搜索interest中含有read的文档  
  
BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();  
//name中含有jack或者interest含有read,相当于or  
boolQueryBuilder.should(queryBuilder1);  
boolQueryBuilder.should(queryBuilder2);

控制台输出(name中含有jack或者interest中含有read的都将被匹配):

------------1------------  
jackson  
1995-08-01  
basketball music reading  
-------------2------------  
angle  
1996-05-01  
singing reading  
-------------3------------  
jack  
1995-03-21  
football music  
-------------4------------  
tom  
1995-09-11  
reading music

6.分页
通过from和size参数进行分页。From定义查询结果开始位置,size定义返回的hits(一条hit对应一条记录)最大数量。

内容从网络获取,如有侵权请及时告知!

 

### Elasticsearch 实现按月范围查询 为了实现在Elasticsearch中按照月份进行搜索的功能,可以采用日期范围查询的方式。这涉及到构建一个`range`类型的查询来指定起始时间和结束时间之间的文档检索。 对于具体的实现方法,在编写查询语句时需注意字段应为日期类型,并且要确保索引中的相应字段已经正确映射为`date`格式[^2]。下面是一个基于给定时间段内的例子: ```json GET /your_index_name/_search { "query": { "range": { "timestamp_field": { "gte": "2023-01-01T00:00:00", "lte": "2023-01-31T23:59:59", "format": "yyyy-MM-dd'T'HH:mm:ss" } } } } ``` 上述JSON展示了如何针对名为`timestamp_field`的时间戳字段执行一个月份(即2023年1月)的数据筛选操作。这里的`gte`代表大于等于某个时间点而`lte`则表示小于等于另一个时间点;同时指定了日期字符串的具体格式以便于解析。 当利用Java API来进行此类查询时,则可通过`QueryBuilder`接口创建相应的查询对象并将其应用于请求之中[^1]。例如: ```java // 构建查询条件 RangeQueryBuilder rangeQuery = QueryBuilders.rangeQuery("timestamp_field") .from("2023-01-01T00:00:00") // 开始时间 .to("2023-01-31T23:59:59") // 结束时间 .includeLower(true) // 是否包含下限 .includeUpper(false); // 是否包含上限 SearchRequest searchRequest = new SearchRequest("your_index_name"); searchRequest.source(new SearchSourceBuilder().query(rangeQuery)); try { SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT); } catch (IOException e) { throw new RuntimeException(e); } ``` 这段代码片段说明了怎样使用官方提供的Java High Level REST Client库完成同样的任务——构造了一个范围查询并将它应用到了实际的搜索请求里。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值