2

这是我来自 CosmosDB 的数据模型:

{
    "id": "100",
    "BookID": "100",
    "PublishDate": "2014-02-23",
    "Authors": [
        {
            "FirstName": "Jerry",
            "Title": "Writer"
        },
        {
            "FirstName": "Sally",
            "Title": "CEO"
        },
        {
            "FirstName": "Tom",
            "Title": "COO"
        }
    ] }

我知道我们可以在Book对象级别进行分页。例如,我可以查询SELECT * FROM c并设置页码和页面大小。

但是,我可以在子对象级别进行分页吗?在这种情况下,在Authors水平上?

我问这个问题是因为我在Book相关查询和Authors相关查询中使用了完全相同的代码。Book查询在页码和页面大小方面具有正确的结果。但是Authors查询总是返回数组中的所有项目。查询Authors是:

从 c 中选择 c.Authors,其中 c.BookID = "100"

结果不正确,页面大小 = 1,页码 = 1。最终返回所有 3 个作者。

所以我在想也许在 Cosmosdb 中它用作Book一个对象,而分页只在Book级别上起作用?这就是为什么级别上的分页Authors不起作用?

4

2 回答 2

2

我认为对分页存在一些误解:分页与返回文档相关,而不是文档的一部分。

如果您要求数组元素,这就是您将得到的。您将获得完整的数组,而不是子集。现在,如果您有 100 个文档,每个文档都具有相同的BookID=100,那么分页将影响这 100 个文档中有多少被返回。

于 2018-08-13T20:06:53.660 回答
0

如果您想在这种情况下查询作者,您可以执行以下操作:

SELECT c.BookID, a.FirstName, a.Title FROM c JOIN a IN c.Authors

这在此处的 CosmosDB 文档中有详细说明:https ://docs.microsoft.com/en-us/azure/cosmos-db/sql-query-join

于 2021-08-09T20:12:50.500 回答