arrays - 如何在 CosmosDB 中为具有嵌套/多个数组的 JSON 文档编写 SQL 查询

标签 arrays azure azure-cosmosdb sql-query-store json-query

我需要在 CosmosDB 查询编辑器中编写一个 SQL 查询,该查询将从存储在 Collection 中的 JSON 文档中获取结果,按照我的要求如下所示

示例 JSON

{
  "id": "abcdabcd-1234-1234-1234-abcdabcdabcd",
  "source": "Example",
  "data": [
    {
      "Laptop": {
        "New": "yes",
        "Used": "no",
        "backlight": "yes",
        "warranty": "yes"
      }
    },
    {
      "Mobile": [
        {
          "order": 1,
          "quantity": 2,
          "price": 350,
          "color": "Black",
          "date": "07202019"
        },
        {
          "order": 2,
          "quantity": 1,
          "price": 600,
          "color": "White",
          "date": "07202019"
        }
      ]
    },
    {
      "Accessories": [
        {
          "covers": "yes",
          "cables": "few"
        }
      ]
    }
  ]
}

要求: 选择特定“日期”的“保修”(笔记本电脑)、“数量”(移动设备)、“颜色”(移动设备)、“电缆”(配件)(例如:07202019)

我尝试了以下查询

SELECT
c.data[0].Laptop.warranty,
c.data[1].Mobile[0].quantity,
c.data[1].Mobile[0].color,
c.data[2].Accessories[0].cables
FROM c
WHERE ARRAY_CONTAINS(c.data[1].Mobile, {date : '07202019'}, true)

上述查询的原始输出:

[
    {
        "warranty": "yes",
        "quantity": 2,
        "color": "Black",
        "cables": "few"
    }
]

但是我怎样才能获得这个预期输出,它在数组“Mobile”中包含所有订单详细信息:

[
    {
        "warranty": "yes",
        "quantity": 2,
        "color": "Black",
        "cables": "few"
    },
    {
        "warranty": "yes",
        "quantity": 1,
        "color": "White",
        "cables": "few"
    }
]

由于我编写了 c.data[1].Mobile[0].quantity 即“Mobile[0]”,它是硬编码的,因此输出中仅返回一个条目(即第一个条目),但我想要列出数组中的所有条目

最佳答案

请考虑在您的 sql 中使用 JOIN 运算符:

SELECT DISTINCT
c.data[0].Laptop.warranty,
mobile.quantity,
mobile.color,
c.data[2].Accessories[0].cables
FROM c
JOIN data in c.data
JOIN mobile in data.Mobile
WHERE ARRAY_CONTAINS(data.Mobile, {date : '07202019'}, true)

输出:

<小时/>

更新答案:

你的sql:

SELECT DISTINCT c.data[0].Laptop.warranty, mobile.quantity, mobile.color, accessories.cables FROM c 
JOIN data in c.data JOIN mobile in data.Mobile 
JOIN accessories in data.Accessories 
WHERE ARRAY_CONTAINS(data.Mobile, {date : '07202019'}, true)

我的建议:

不得不说,实际上Cosmos DB JOIN操作仅限于单个文档的范围。您可以将父对象与子对象连接到同一文档下。不支持跨文档联接。但是,您的 sql 尝试实现多个并行联接。换句话说,Accessories 和 Mobile 是分层的,而不是嵌套的。

我建议你使用存储过程来执行两条sql,而不是将它们放在一起。或者您可以在代码中实现上述过程。

请看这个案例:CosmosDB Join (SQL API)

关于arrays - 如何在 CosmosDB 中为具有嵌套/多个数组的 JSON 文档编写 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57439281/

相关文章:

javascript - JavaScript 数组中的唯一计数,按计数排序

java - 递归 - 与 in array 组合,在 Java 中没有重复

database - Blob 文件未出现在查询编辑器中

sql-server - 尽管连接数远低于资源限制,但已达到 Azure Sql 请求限制

sql-server - 目标平台 Azure SQL 数据库不支持创建搜索属性列表

azure - 将默认 CosmosSerializationOptions 更改为驼峰命名法会导致 CosmosDB SDK V4 中出现异常

objective-c - 在 Objective-C 中选择 NSArray 的随机元素

php:推送到一个可能存在也可能不存在的数组

javascript - Azure cosmos DB 仅在查询中允许最多 5 个联接

azure - DocumentDB/CosmosDB - 系统中不存在具有指定 ID 的实体