要更新BigQuery中的多个嵌套列,您可以使用STRUCT构造函数和ARRAY构造函数来构建更新语句。下面是一个包含代码示例的解决方法:
假设您有一个名为my_table
的表,其中包含一个名为nested_column
的嵌套列,您想要更新其中的nested_column.field1
和nested_column.field2
字段。
UPDATE `project.dataset.my_table`
SET nested_column = STRUCT(
ARRAY(
SELECT AS STRUCT
IF(field1 = "old_value", "new_value", field1) AS field1,
IF(field2 = "old_value", "new_value", field2) AS field2,
field3,
...
FROM UNNEST(nested_column)
) AS nested_column
)
WHERE ... -- 可选的WHERE子句用于过滤要更新的行
请按以下步骤操作:
STRUCT
函数和ARRAY
函数来构建您要更新的嵌套列的新值。在ARRAY
函数中,使用SELECT AS STRUCT
将每一行转换为一个结构体。SELECT
子句中,使用IF
函数来检查要更新的字段的值。如果值等于旧值,则使用新值进行更新;否则,保持字段的原始值。FROM UNNEST
子句中,展开nested_column
以遍历每一行。nested_column
重新构造为一个嵌套列。WHERE
子句中添加条件来过滤要更新的行。请根据您的具体需求修改字段名、条件和表名。