BigQuery:获取STRUCT的字段名称

时间:2020-08-25 11:26:43

标签: google-bigquery

我在BigQuery的STRUCT中有一些数据。下面,我将数据可视化为JSON的示例:

{ 
  ...
  siblings: {
    david: { a: 1 }
    sarah: { b: 1, c: 1 }
  }
  ...
}

我想从类似于["david", "sarah"]的查询中产生一个字段。本质上,我只想从STRUCT(对象)中获取密钥。请注意,每个用户在同级STRUCT中都有不同的键名。

在BigQuery中这可能吗?

谢谢, A

1 个答案:

答案 0 :(得分:0)

您的结构模式必须在整个表中保持一致。它们不能更改键,因为它们是表架构的一部分。要获取键,您只需看一下表模式。

如果值发生变化,则可能是数组中的值-我想您可能会有这样的东西:

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"
      }
    ]
  }