跳到主要内容

FLATTEN

引入或更新于:v1.2.213

将嵌套的 JSON 或数组数据转换为表格格式,其中每个元素或字段表示为单独的行。

语法

[LATERAL] FLATTEN (
INPUT => <expr>
[, PATH => <expr>]
[, OUTER => TRUE | FALSE]
[, RECURSIVE => TRUE | FALSE]
[, MODE => 'OBJECT' | 'ARRAY' | 'BOTH']
)

参数

参数说明默认值
INPUT要展平的 JSON 或数组数据必需
PATH要展平的数组/对象的路径
OUTER包含结果为零的行(即值为 NULL 的行)FALSE
RECURSIVE递归展平嵌套元素FALSE
MODE展平对象、数组或两者'BOTH'
LATERAL启用与前面表表达式的交叉引用可选

输出列

说明
SEQ输入的序列号
KEY展开值的键(如果没有则为 NULL)
PATH展平元素的路径
INDEX数组索引(对于对象为 NULL)
VALUE展平元素的值
THIS正在被展平的元素

注意: 使用 LATERAL 时,由于动态交叉引用,输出列可能有所不同。

示例

基本展平

-- Flatten a JSON object with nested structures
SELECT * FROM FLATTEN(
INPUT => PARSE_JSON(
'{"name": "John", "languages": ["English", "Spanish"], "address": {"city": "New York"}}'
)
);

结果是顶层键被展平:

| seq | key       | path      | index | value                | this                 |
|-----|-----------|-----------|-------|----------------------|----------------------|
| 1 | name | name | NULL | "John" | {original JSON} |
| 1 | languages | languages | NULL | ["English","Spanish"]| {original JSON} |
| 1 | address | address | NULL | {"city":"New York"} | {original JSON} |

使用 PATH 参数

-- Flatten only the languages array by specifying the PATH
SELECT * FROM FLATTEN(
INPUT => PARSE_JSON(
'{"name": "John", "languages": ["English", "Spanish"]}'
),
PATH => 'languages'
);

结果是数组元素被展平:

| seq | key  | path         | index | value     | this               |
|-----|------|--------------|-------|-----------|-------------------|
| 1 | NULL | languages[0] | 0 | "English" | ["English","Spanish"] |
| 1 | NULL | languages[1] | 1 | "Spanish" | ["English","Spanish"] |

递归展平

-- Recursively flatten nested objects and arrays
SELECT * FROM FLATTEN(
INPUT => PARSE_JSON(
'{"name": "John", "address": {"city": "New York", "zip": 10001}}'
),
RECURSIVE => TRUE
);

结果是嵌套对象被展平:

| seq | key     | path         | index | value       | this            |
|-----|---------|--------------|-------|-------------|-----------------|
| 1 | name | name | NULL | "John" | {original JSON} |
| 1 | address | address | NULL | {"city":...}| {original JSON} |
| 1 | city | address.city | NULL | "New York" | {"city":...} |
| 1 | zip | address.zip | NULL | 10001 | {"city":...} |

使用 LATERAL FLATTEN

-- Use LATERAL FLATTEN to transform a JSON array into rows
SELECT
f.value:item::STRING AS item_name,
f.value:price::FLOAT AS price
FROM
LATERAL FLATTEN(
INPUT => PARSE_JSON('[
{"item":"coffee", "price":2.50},
{"item":"donut", "price":1.20}
]')
) f;

结果:

| item_name | price |
|-----------|-------|
| coffee | 2.5 |
| donut | 1.2 |
开始使用 Databend Cloud
低成本
快速分析
多种数据源
弹性扩展
注册