如何解决BigQuery:获取STRUCT的字段名称
我在BigQuery的STRUCT中有一些数据。下面,我将数据可视化为JSON的示例:
{
...
siblings: {
david: { a: 1 }
sarah: { b: 1,c: 1 }
}
...
}
我想从类似于["david","sarah"]
的查询中产生一个字段。本质上,我只想从STRUCT(对象)中获取密钥。请注意,每个用户在同级STRUCT中都有不同的键名。
在BigQuery中这可能吗?
谢谢, A
解决方法
您的结构模式必须在整个表中保持一致。它们不能更改键,因为它们是表架构的一部分。要获取键,您只需看一下表模式。
如果值发生变化,则可能是数组中的值-我想您可能会有这样的东西:
WITH t AS (
SELECT 1 AS id,[STRUCT('david' AS name,33 as age),('sarah',42)] AS siblings
union all
SELECT 2,[('ken',19),('ryu',21),('chun li',23)]
)
SELECT * FROM t
如果您试图在第二行或数组中引入新键,则会出现错误Array elements of types {...} do not have a common supertype at ...
。
上面示例中以json表示形式的第一个元素如下:
{
"id": "1","siblings": [
{
"name": "david","age": "33"
},{
"name": "sarah","age": "42"
}
]
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。