如何使用DML语法更新BigQuery中的嵌套记录?

时间:2017-01-13 15:58:59

标签: google-bigquery

我已经获得了以下BigQuery架构,并且我尝试更新event_dim.date字段:

enter image description here

我使用标准SQL和新的BigQuery DML尝试了以下查询:

UPDATE `sara-bigquery.examples.app_events_20170113`
SET event_dim.date = '20170113'
WHERE true

但得到了这个错误:

Error: Cannot access field date on a value with type ARRAY<STRUCT<name STRING, params ARRAY<STRUCT<key STRING, 
value STRUCT<string_value STRING, int_value INT64, float_value FLOAT64, ...>>>, timestamp_micros INT64, ...>> at [2:15]

我可以使用此查询选择嵌套字段:

 SELECT x.date FROM `sara-bigquery.examples.app_events_20170113`,
 UNNEST(event_dim) x

但无法找出正确的UPDATE语法。

1 个答案:

答案 0 :(得分:6)

该查询失败,因为event_dim是一个结构数组。这应该可以解决问题:

UPDATE `sara-bigquery.examples.app_events_20170113`
SET event_dim = ARRAY(
  SELECT AS STRUCT * REPLACE('20170113' AS date) FROM UNNEST(event_dim)
)
WHERE true

有关详细信息,请查看有关如何在标准SQL中处理数组的docs