我面临一个问题,其中提取的文件列可能会因不同而发生变化:例如:
在第 1 天,文件可能有 3 列:c1、c2、c3 在第 2 天,文件可能有 5 列:c1、c3、c2、 c4,c5 注意第二个文件中 c3 的列位置。
在雪花中使用外部阶段语法中的“复制到”将不起作用,因为 c3 列是在 c1 之后引入的。尝试使用外部表,但它还需要一个位置列才能工作。有没有人想出如何加载这些类型的文件?
我面临一个问题,其中提取的文件列可能会因不同而发生变化:例如:
在第 1 天,文件可能有 3 列:c1、c2、c3 在第 2 天,文件可能有 5 列:c1、c3、c2、 c4,c5 注意第二个文件中 c3 的列位置。
在雪花中使用外部阶段语法中的“复制到”将不起作用,因为 c3 列是在 c1 之后引入的。尝试使用外部表,但它还需要一个位置列才能工作。有没有人想出如何加载这些类型的文件?
您没有告诉任何有关正在使用的格式的信息。
加载不同列的唯一方法是从文件加载为单个列,例如。withFIELD_DELIMITER = NONE
和 split & 转换成OBJECT
以每个文件列作为属性。
如果第一条记录包含字段名称 c1 ... c n,您可以加载:
WITH
file AS (SELECT * FROM VALUES ('c1,c2,c3'), ('1,2,3'), ('11,22,33') t(REC)),
split_file AS (SELECT * FROM file CROSS JOIN LATERAL SPLIT_TO_TABLE(REC, ','))
combined_table AS (
SELECT content.SEQ - 1 REC_NO, OBJECT_AGG(headers.VALUE, content.VALUE::VARIANT) OBJ
FROM split_file content
INNER JOIN split_file headers
ON content.INDEX = headers.INDEX AND content.SEQ > 1 AND headers.SEQ = 1
GROUP BY content.SEQ
)
SELECT OBJ:c1::NUMBER c1, OBJ:c2::NUMBER c2, OBJ:c3::NUMBER c3, OBJ:c4::NUMBER c4
FROM combined_table;
上面的示例将所有内容组合到一个查询中,但在您的情况下,您必须单独聚合每个文件并INSERT
(附加)到combined_table
.
这样做的原因是您可以引用不存在的对象属性(列)(例如c4),它们将被替换为NULL
.