登录
首页 >  Golang >  Go问答

Golang和CosmosDB的分页实现

来源:stackoverflow

时间:2024-02-07 23:45:23 201浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《Golang和CosmosDB的分页实现》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在尝试使用 cosmosapi 包从 cosmosdb 选择记录时实现分页。 天蓝色文档指出,延续令牌永不过期,我正在尝试理解其语义。

在 cosmos db 延续令牌如何工作?有一项协议是

提供第一页后创建的文档可在 后续页面

我试图通过从 golang 应用程序运行一些实验来验证这一点,但有些事情不太正确。作为一个非常高级的示例,如果我们向 cosmosdb 插入三个记录:

insert record #1
insert record #2
insert record #3

然后,如果我们尝试使用以下选项从表中进行选择(query = select * from c order by c.datefield desc):

opts := cosmosapi.querydocumentsoptions{
    isquery:              true,
    contenttype:          cosmosapi.query_content_type,
    consistencylevel:     cosmosapi.consistencylevelstrong,
    continuation:         "",
    partitionkeyvalue:    partitionkeyvalue,
    maxitemcount:         2,
}

它返回:

record #1
record #2 
continuation token = "cont-token-1"

现在,当使用相同的选项再次选择但不同的继续标记时:

opts := cosmosapi.querydocumentsoptions{
    isquery:              true,
    contenttype:          cosmosapi.query_content_type,
    consistencylevel:     cosmosapi.consistencylevelstrong,
    continuation:         "cont-token-1",
    partitionkeyvalue:    partitionkeyvalue,
    maxitemcount:         2,
}

返回

record #3

这是相当合乎逻辑的。 现在,当我尝试插入记录#4,并且它在记录#3之后插入,并尝试使用“cont-token-1”获取时,记录#4不会显示。仅当我通过使用空 opts.continuation 字段再次选择来重新生成延续令牌时,它才会显示。

如果我尝试使用空的延续令牌进行选择,那么它会获取记录 #1 和记录 #2,并生成一个新的令牌来获取记录 #3 和记录 #4。

这是预期的行为吗?或者我错过了什么? 根据我的理解,它应该出现。延续令牌就像一个书签,即使使用相同的延续令牌,它也应该看到结果。


正确答案


连续令牌只能与完全相同的查询一起使用,并且每次都会返回完全相同的答案,无论您如何更改基础数据,如果您的基础数据以这种方式更改,您都需要获取新令牌这将包含在第一个答案中。

今天关于《Golang和CosmosDB的分页实现》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>