JSON 通过 Snowflake 中的目标 Table 扁平化的替代方案
Alternative to JSON Flattening via Target Table in Snowflake
每个雪花:https://docs.snowflake.net/manuals/user-guide/json-basics-tutorial-copy-into.html 我创建了一个目标 table (Testing_JSON),这是一个包含上传的 JSON 文件的变体列。
我的问题是我怎样才能停止创建这个 "Target Table (i.e. Testing_JSON)" 这是我必须引用的单个变体列来创建我想要的实际且唯一的 table ( TABLE1),其中包含扁平化的 JSON。我发现无法从我的桌面读取 JSON 文件并 'parse it on the fly' 通过 UI 创建扁平的 table。不使用 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);
您需要在桌面上通过几个步骤完成此操作。
- 使用 SnowSQL 或其他工具将您的 JSON 文件变为 blob
贮存:
https://docs.snowflake.net/manuals/sql-reference/sql/put.html
- 使用 COPY INTO 语句将数据直接加载到要加载到的扁平化 table 中。这将需要在您的 COPY INTO 中使用 SELECT 语句:
https://docs.snowflake.net/manuals/sql-reference/sql/copy-into-table.html
这里有一个很好的例子:
您不能通过 UI 执行此操作。如果你想这样做,那么你需要在你的桌面上使用一个外部工具,或者——正如 Mike 提到的——在 COPY 语句中。
每个雪花:https://docs.snowflake.net/manuals/user-guide/json-basics-tutorial-copy-into.html 我创建了一个目标 table (Testing_JSON),这是一个包含上传的 JSON 文件的变体列。
我的问题是我怎样才能停止创建这个 "Target Table (i.e. Testing_JSON)" 这是我必须引用的单个变体列来创建我想要的实际且唯一的 table ( TABLE1),其中包含扁平化的 JSON。我发现无法从我的桌面读取 JSON 文件并 'parse it on the fly' 通过 UI 创建扁平的 table。不使用 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);
您需要在桌面上通过几个步骤完成此操作。
- 使用 SnowSQL 或其他工具将您的 JSON 文件变为 blob 贮存: https://docs.snowflake.net/manuals/sql-reference/sql/put.html
- 使用 COPY INTO 语句将数据直接加载到要加载到的扁平化 table 中。这将需要在您的 COPY INTO 中使用 SELECT 语句: https://docs.snowflake.net/manuals/sql-reference/sql/copy-into-table.html
这里有一个很好的例子:
您不能通过 UI 执行此操作。如果你想这样做,那么你需要在你的桌面上使用一个外部工具,或者——正如 Mike 提到的——在 COPY 语句中。