首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用DML语法更新BigQuery中的嵌套记录?

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

Stack Overflow用户
提问于 2017-01-13 23:58:59
回答 1查看 2.4K关注 0票数 7

我得到了以下BigQuery模式,并且我正在尝试更新event_dim.date字段:

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

代码语言:javascript
运行
复制
UPDATE `sara-bigquery.examples.app_events_20170113`
SET event_dim.date = '20170113'
WHERE true

但是得到了这个错误:

代码语言:javascript
运行
复制
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]

我可以使用下面的查询选择嵌套字段:

代码语言:javascript
运行
复制
 SELECT x.date FROM `sara-bigquery.examples.app_events_20170113`,
 UNNEST(event_dim) x

但是找不到正确的UPDATE语法。

EN

回答 1

Stack Overflow用户

发布于 2017-01-13 23:58:59

该查询失败,因为event_dim是一个结构数组。这应该能起到作用:

代码语言:javascript
运行
复制
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

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41638651

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档