java中的接口是类吗
512
2022-12-31
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
http://
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 queryBuidAfAFPwMYflder2 = 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对应一条记录)最大数量。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~