要将数据从一个嵌套表复制到另一个嵌套表,您可以使用BigQuery的INSERT INTO语句和SELECT语句。以下是解决方法的示例代码:
-- 创建源表
CREATE TABLE source_table (
id INT64,
name STRING,
addresses ARRAY>
);
-- 创建目标表
CREATE TABLE target_table (
id INT64,
name STRING,
addresses ARRAY>
);
-- 插入数据到源表
INSERT INTO source_table (id, name, addresses)
VALUES
(1, 'John Doe', [
STRUCT('123 Main St', 'New York', 'USA'),
STRUCT('456 Elm St', 'Los Angeles', 'USA')
]),
(2, 'Jane Smith', [
STRUCT('789 Oak St', 'Chicago', 'USA'),
STRUCT('987 Pine St', 'San Francisco', 'USA')
]);
-- 使用INSERT INTO和SELECT语句将数据从源表复制到目标表
INSERT INTO target_table (id, name, addresses)
SELECT id, name, addresses
FROM source_table;
-- 查询目标表以验证数据是否复制成功
SELECT * FROM target_table;
在上面的示例中,我们首先创建了一个源表 source_table
和一个目标表 target_table
,它们都具有相同的结构。然后,我们使用INSERT INTO语句将数据从源表复制到目标表。最后,我们查询目标表以验证数据是否成功复制。
请注意,如果目标表已经存在并且您只想将数据追加到目标表中,您可以使用INSERT INTO语句的 APPEND
选项。例如:
INSERT INTO target_table (id, name, addresses)
SELECT id, name, addresses
FROM source_table
-- 使用APPEND选项将数据追加到目标表
OPTIONS(
insert_method='APPEND'
);
这将在目标表中追加与源表相同的数据,而不会覆盖目标表中的现有数据。