0

我面临一个问题,其中提取的文件列可能会因不同而发生变化:例如:
在第 1 天,文件可能有 3 列:c1、c2、c3 在第 2 天,文件可能有 5 列:c1、c3、c2、 c4,c5 注意第二个文件中 c3 的列位置。

在雪花中使用外部阶段语法中的“复制到”将不起作用,因为 c3 列是在 c1 之后引入的。尝试使用外部表,但它还需要一个位置列才能工作。有没有人想出如何加载这些类型的文件?

4

1 回答 1

1

您没有告诉任何有关正在使用的格式的信息。

加载不同列的唯一方法是从文件加载为单个列,例如。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.

于 2019-11-21T09:18:21.463 回答