繁体   English   中英

通过雪花中的目标表展平 JSON 的替代方案

[英]Alternative to JSON Flattening via Target Table in Snowflake

Per snowflake: https://docs.snowflake.net/manuals/user-guide/json-basics-tutorial-copy-into.html I created a target table (Testing_JSON), that is a single Variant column that contains an uploaded JSON文件。

我的问题是如何创建这个“目标表(即 Testing_JSON)”,它是一个单一的变体列,我必须引用它来创建我想要的实际且唯一的表(TABLE1),其中包含扁平的 JSON。 我发现无法从我的桌面读取 JSON 文件并“动态解析”以通过 UI 创建扁平表。 不使用 CLI,因为我知道这可以使用 PUT/COPY INTO 来完成

create or replace temporary table TABLE1 AS
SELECT 
VALUE:col1::string AS COL_1,
VALUE:col2::string AS COL_2,
VALUE:col3::string AS COL_3

from TESTING_JSON 
  , lateral flatten( input => json:value);

您将需要在桌面上通过几个步骤执行此操作。

  1. 使用 SnowSQL 或其他工具将 JSON 文件获取到 blob 存储: https://docs.snowflake.net/manuals/sql-reference/sql/put.ZFC35FDC70D5FC69D269883A822
  2. 使用 COPY INTO 语句将数据直接加载到要加载到的展平表中。 这将需要在您的 COPY INTO 中使用 SELECT 语句: https://docs.snowflake.net/manuals/sql-reference/sql/copy-into-table.ZFC35FDC70D5FC69D269883A82CZ2

这里有一个很好的例子:

https://docs.snowflake.net/manuals/user-guide/querying-stage.html#example-3-querying-elements-in-a-json-file

您无法通过 UI 执行此操作。 如果你想这样做,那么你需要在你的桌面上使用一个外部工具,或者——正如 Mike 提到的——在 COPY 语句中。

Here is the link to one of my previous replies to extract the elements.

https://stackoverflow.com/questions/58486204/how-should-i-load-xml-file-which-has-comments-and-spaces-in-them-and-then-using/58514826#58514826

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM