【发布时间】:2023-08-25 11:57:01
【问题描述】:
我有一个网络爬虫将数据转储到雪花数据库的变体列中。 这是为了创建页面数据,然后为页面中的各种表创建 json 数组。
这是我使用足球类比找到的 json 类型的示例:
{
"dom_url": "https://www.soccertables.com/european_tables",
"event_id": "01b2722a-d8e6-4f67-95d0-8dd7ba088a4a",
"event_utc_time": "2020-05-11 09:01:14.821",
"ip_address": "125.238.134.96",
"table_1": [
{
"position": "1",
"team_name": "Liverpool",
"games_played": "29",
"games_won": "26",
"games_drawn": "2",
"games_lost": "1",
"goals_for": "75",
"goals_against": "35"
"points": "80"
},
{
"position": "2",
"team_name": "Man. City",
"games_played": "29",
"games_won": "20",
"games_drawn": "5",
"games_lost": "4",
"goals_for": "60",
"goals_against": "45"
"points": "65"
},
{
"position": "...",
"team_name": "...",
"games_played": "...",
"games_won": "...",
"games_drawn": "...",
"games_lost": "...",
"goals_for": "...",
"goals_against": "..."
"points": "..."
}
],
"table_2": [
{
"position": "1",
"team_name": "Bayern Munich",
"games_played": "29",
"games_won": "26",
"games_drawn": "2",
"games_lost": "1",
"goals_for": "75",
"goals_against": "35"
"points": "80"
},
{
"position": "2",
"team_name": "Bayer Leverkussen",
"games_played": "29",
"games_won": "20",
"games_drawn": "5",
"games_lost": "4",
"goals_for": "60",
"goals_against": "45"
"points": "65"
},
{
"position": "...",
"team_name": "...",
"games_played": "...",
"games_won": "...",
"games_drawn": "...",
"games_lost": "...",
"goals_for": "...",
"goals_against": "..."
"points": "..."
}
],
"referrer_url": "https://www.soccertables.com",
}
理想情况下,我希望它的输出是一个平面的关系表:
table_name 位置 team_name games_played 等等... table_1 1 利物浦 29 ... table_1 2 人。 29市... table_2 1 拜仁慕尼黑 29 ... ....
我知道,如果我只对 table_1 感兴趣,我可以这样做:
SELECT v.value:position::NUMBER POSITION
, v.value:team_name::STRING TEAM_NAME
, v.value:games_played::NUMBER GAMES_PLAYED
, ...
FROM JSON_TABLE a1, LATERAL FLATTEN(JSON_DATA:table_1) v
我可以对 table_2 做同样的事情并将它们合并,但是对于 table_N 占位符可能有 N 种可能性。
我多次看过 LATERAL FLATTEN:
SELECT v.value:position::NUMBER POSITION
, v.value:team_name::STRING TEAM_NAME
, v.value:games_played::NUMBER GAMES_PLAYED
, ...
FROM JSON_TABLE a1, LATERAL FLATTEN(JSON_DATA:table_1) v, LATERAL FLATTEN(JSON_DATA:table_2) v2
但这会导致数据重复,并且不允许我将每个表的列全部放在一个关系结构中。
我确定我在这里缺少一些简单的东西,但我已经到了一个地步,我认为我已经盯着这个太久了,只是看不到它。
提前致谢, S
【问题讨论】:
-
每个表格是否具有相同的元素,而您只是试图将它们全部展平到相同的视图/表格结构中?
标签: sql snowflake-cloud-data-platform flatten