如何在Presto Athena中将varchar转换为数组 [英] How to convert varchar to array in Presto Athena
本文介绍了如何在Presto Athena中将varchar转换为数组的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我的数据为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中解决此问题?
SQL
您可以组合使用parsing the value as JSON,将其转换为结构化推荐答案类型(数组/映射/行),以及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)
这篇关于如何在Presto Athena中将varchar转换为数组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文