我们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条数据
// 入参为上次调用的返回值,即上次查询最后一条