4

我的数据是VARCHAR格式的。我想拆分这个数组的两个元素,以便我可以从 JSON 中提取一个键值。

数据格式

[
  {
    "skuId": "5bc87ae20d298a283c297ca1",
    "unitPrice": 0,
    "id": "5bc87ae20d298a283c297ca1",
    "quantity": "1"
  },
  
{
    "skuId": "182784738484wefhdchs4848",
    "unitPrice": 50,
    "id": "5bc87ae20d298a283c297ca1",
    "quantity": "4"
  },
]

例如我想skuid从上面的列中提取。所以我提取后的数据应该是这样的:

1 5bc87ae20d298a283c297ca1
2 182784738484wefhdchs4848

投射到数组也不起作用:

SELECT CAST(col AS ARRAY)

给出以下错误:

未知类型:数组

所以我无法取消嵌套数组。

我如何在Presto Athena中解决这个问题?

4

1 回答 1

8

您可以使用将值解析为 JSON、将其转换为结构化 SQL 类型(数组/映射/行)和UNNEST WITH ORDINALITY的组合来从数组中提取元素作为单独的行。请注意,这仅适用于 JSON 有效负载中的数组元素没有尾随逗号的情况。您的示例有一个,但已从下面的示例中删除。

WITH data(value) AS (VALUES
 '[
    {
      "skuId": "5bc87ae20d298a283c297ca1",
      "unitPrice": 0,
      "id": "5bc87ae20d298a283c297ca1",
      "quantity": "1"
    },
    {
      "skuId": "182784738484wefhdchs4848",
      "unitPrice": 50,
      "id": "5bc87ae20d298a283c297ca1",
      "quantity": "4"
    }
  ]'
),
parsed(entries) AS (
  SELECT cast(json_parse(value) AS array(row(skuId varchar)))
  FROM data
)
SELECT ordinal, skuId
FROM parsed, UNNEST(entries) WITH ORDINALITY t(skuId, ordinal)

产生:

 ordinal |          skuId
---------+--------------------------
       1 | 5bc87ae20d298a283c297ca1
       2 | 182784738484wefhdchs4848
(2 rows)
于 2019-05-16T20:32:49.470 回答