首先推荐两个博主的帖子很不错
ElasticSearch的结构分析:https://blog.csdn.net/tianyaleixiaowu/article/details/76149547
ElasticSearch简单介绍及jpa分析:https://blog.csdn.net/KingBoyWorld/article/details/78654820
ElasticSearch官方中文文档:https://es.xiaoleilu.com/010_Intro/05_What_is_it.html
自己看完总结
Springboot整合elasticsearch的JPA的使用
DAO层继承ElasticsearchRepository <T,ID>,和其他springdata的存储库一样有find / save / del / insert,其中spring-data-elasticsearch有特殊的搜索方法,用来构建一些ES查询的。
search()可以传QueryBuilder对象Pageble分页对象SearchQuery对象,返回Iterator <T>
可以fore()循环得到值
也可以迭代器获得
Iterator<User> iterator = searchResult.iterator();
List<User> list=new ArrayList<User>();
while (iterator.hasNext()) {
list.add(iterator.next());
}
SearchQuery是一个接口,他可以组合多个条件(QueryBuilder对象)通过新的NativeSearchQuery他的实现类来实现它。
我们可以看到要构建NativeSearchQuery,主要是需要几个构造参数
public NativeSearchQuery(QueryBuilder query, QueryBuilder filter, List<SortBuilder> sorts, Field[] highlightFields) {
this.query = query;
this.filter = filter;
this.sorts = sorts;
this.highlightFields = highlightFields;
}
可以看出来,大概是需要的QueryBuilder构造器,过滤器,和排序的SortBuilder构造器,和高亮的字段。
一般情况下,我们不是直接是新的NativeSearchQuery,而是使用NativeSearchQueryBuilder。
。通过NativeSearchQueryBuilder.withQuery(QueryBuilder1).withFilter(QueryBuilder2).withSort(SortBuilder1).withXXXX()建立();这样的方式来完成NativeSearchQuery的构建。
QueryBuilder的查询对象
QueryBuilders是一个抽象类,QueryBuilders.xxx可以得到XX的QueryBuilder的对象,下面列举XX
matchAllQuery查询所有文档
queryStringQuery现将参数分词,再拿分词的结果依次查询,合并查询的结果
termQuery词条查询(完全匹配)
wildcardQuery通配符的词条查询
boolQuery组合其他的查询条件
fuzzyQuery相似度查询
SortBuilder排序构造器
SortBuilders是一个抽象类,SortBuilders.xxx可以得到XX的SortBuilder对象,下面列举XX
不常用
关于API的使用
springboot data 的elasticSearch的JPI 内部其实是用 QueryBuilder的对象实现的查询,弹簧数据可以使用组合查询查询复杂数据,QueryBuiler可以通过boolQuery组合条件查询复杂数据。
有理解不对的希望各路大神指正。共同学习!