【微服务】162:利用Java实现索引库相关的分页、排序和聚合

今天是刘小爱自学Java的第162天 。
感谢你的观看 , 谢谢你 。
【微服务】162:利用Java实现索引库相关的分页、排序和聚合
文章图片
学习计划安排 , 利用Java代码来实现对索引库的各种操作:
通过自定义方法实现匹配查询、范围查询 。
原生的查询代码又是如何编写的?
最后还有聚合相关的代码编写 。
一、自定义方法
昨天学了最基础的几种增删改查方法 , 但查询在实际应用中显然没这么简单 。
比如用户要匹配查询 , 前几天我们有学过 , 有match匹配和term匹配两种常用的方式 。
这些在Java中又是哪些方法来对应呢?
有原生的方法可以是使用 , 但是比较麻烦 , 这里使用springdata提供的自定义方法 。
1自定义方法实现多种查询方法
【微服务】162:利用Java实现索引库相关的分页、排序和聚合
文章图片
昨天有使用到findAll()方法 , 这是自带的方法 , 看其语义也就能知道其实查询所有数据 。
但是很多时候并不是一个查询所有方法就能解决的 , 所以需要自己自定义说明 。
queryItemsByTitleMatchs
方法名一定要按照其格式来 , 一看到也就很好理解 , 是根据Title这个字段匹配查询 。
其中后面还可以接“And”“Or”这些逻辑运算 , 实现布尔查询 。
queryItemsByPriceBetween
一样的道理 , 范围查询也有其格式 , 也就是between这个单词的使用 。
总之:自定义方法之后 , 不需要我们写具体是如何查询的了 , 可以直接使用 , 但是方法名需要遵循命名规范 , 如果不能正常使用 , 极有可能就是方法名格式不对 。
2自定义方法的使用
【微服务】162:利用Java实现索引库相关的分页、排序和聚合
文章图片
根据Title词条匹配
直接调用自定义的match匹配方法 , 在参数中说明要搜索的关键字是“小米手机” , 这样就能match匹配到和“小米手机”相关的数据了 。
【微服务】162:利用Java实现索引库相关的分页、排序和聚合】根据price范围查询
直接调用自定义的范围查询方法 , 在参数中说明价格区间是2000-4000 , 这样也就能范围查询出这个价格区间相关的数据了 。
3运行方法 , 观察结果
【微服务】162:利用Java实现索引库相关的分页、排序和聚合
文章图片
“小米手机”匹配结果
这个前几天专门说明过 , 因为title这个字段类型是text , 是要分词的 , 所以“小米手机”被分词成了“小米”和“手机” 。
只要是和上述分词相关的数据都会被查询出来 , 所以“坚果手机”也被查询出来了 。
价格在2000-4000区间的数据
结果也就显而易见了 , 如上图所示 。
二、原生的查询
自定义方法虽然很简单 , 但有时候不能很好地实现业务需求 , 比如查询条件过多时 。
这个时候就需要结合官方提供的原生查询了 。
【微服务】162:利用Java实现索引库相关的分页、排序和聚合
文章图片
创建查询的构造器
NativeSearchQueryBuilder也就是原生搜索查询构造器的意思 , 通过它也就可以添加各种查询条件 。
添加查询条件
withQuery():QueryBuilders说明查询
例子中是match匹配查询 , 所以在Java中也就是matchQuery方法 , 参数:title是字段 , “小米手机”是该字段对应的数据 。
withPageable():PageRequest实现分页
of()方法即可实现分页 , 其中页面数从0页开始 , 每页大小上述图中指定的是2 。
withSort():SortBuilders实现排序
fieldSort()方法说明需要排序的字段 。