Elasticsearch QueryBuilder简单查询实现解析

所属分类: 软件编程 / java 阅读数: 32
收藏 0 赞 0 分享

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对应一条记录)最大数量。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Springmvc restful配置遇到的小坑

本文是小编给大家带了的Springmvc restful配置遇到的小小坑,小编给大家带来了问题原因及解决办法,非常不错,具有参考借鉴价值,感兴趣的朋友一起看下吧
收藏 0 赞 0 分享

Java中的匿名内部类小结

java内部类分为: 成员内部类、静态嵌套类、方法内部类、匿名内部类。这篇文章主要介绍了Java中的匿名内部类的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java的云打印Lodop

这篇文章主要介绍了Java的云打印Lodop 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Java线程池框架核心代码解析

这篇文章主要针对Java线程池框架核心代码进行详细解析,分析Java线程池框架的实现ThreadPoolExecutor,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Java 交换两个变量的数值实现方法

下面小编就为大家带来一篇Java 交换两个变量的数值实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

全面了解JAVA_BaseDAO数据处理类

下面小编就为大家带来一篇全面了解JAVA_BaseDAO数据处理类。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

java、python、JavaScript以及jquery循环语句的区别

本篇文章主要介绍java、python、JavaScript以及jquery的循环语句的区别,这里整理了它们循环语句语法跟示例,以便大家阅读,更好的区分它们的不同
收藏 0 赞 0 分享

基于JDBC封装的BaseDao(实例代码)

下面小编就为大家带来一篇基于JDBC封装的BaseDao(实例代码)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

简单通用JDBC辅助类封装(实例)

下面小编就为大家带来一篇简单通用JDBC辅助类封装(实例)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

浅谈java线程中生产者与消费者的问题

下面小编就为大家带来一篇浅谈java线程中生产者与消费者的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多