go语言使用olivere/elastic es客户端实现SearchAfter深度分页

我们go项目里使用的es客户端是olivere/elastic包,资料比较少,SearchAfter的实现更是少,所以记录下来给有缘人,也给记性差的自己。

关于深度分页、浅分页的区别优缺点另行了解,我的es版本是6.4,过低版本会不支持

关于SearchAfter官方的简单实例

https://www.elastic.co/guide/en/elasticsearch/reference/6.4/search-request-search-after.html

简单演示下客户端的创建:

import "github.com/olivere/elastic"
// 获取客户端对象,这里可以包装单例使用
esClient, err = elastic.NewClient(
   elastic.SetURL(你的es库host,多参数),
   elastic.SetSniff(false),
   elastic.SetHealthcheckInterval(10 * time.Second),
   elastic.SetGzip(true),
)

 查询方法

其中Query方法的参数需要各位组装自己的查询条件,参考官方实例

忽略了数据的处理和,重点在深度分页的用法

// 深度分页查询方法,根据上一次查询的最后一条数据(该条数据的中用于排序的字段值,支持多字段)查询size条数据
// 入参为上次调用的返回值,即上次查询最后一条
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值