mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-18 21:51:57 +00:00
25 lines
988 B
SQL
25 lines
988 B
SQL
-- Tags: no-fasttest
|
|
|
|
DROP TABLE IF EXISTS t_flatten_tuple;
|
|
DROP TABLE IF EXISTS t_flatten_object;
|
|
|
|
SET flatten_nested = 0;
|
|
|
|
CREATE TABLE t_flatten_tuple(t Tuple(t1 Nested(a UInt32, s String), b UInt32, t2 Tuple(k String, v UInt32))) ENGINE = Memory;
|
|
|
|
INSERT INTO t_flatten_tuple VALUES (([(1, 'a'), (2, 'b')], 3, ('c', 4)));
|
|
|
|
SELECT flattenTuple(t) AS ft, toTypeName(ft) FROM t_flatten_tuple;
|
|
|
|
SET allow_experimental_object_type = 1;
|
|
CREATE TABLE t_flatten_object(data JSON) ENGINE = Memory;
|
|
|
|
INSERT INTO t_flatten_object VALUES ('{"id": 1, "obj": {"k1": 1, "k2": {"k3": 2, "k4": [{"k5": 3}, {"k5": 4}]}}, "s": "foo"}');
|
|
INSERT INTO t_flatten_object VALUES ('{"id": 2, "obj": {"k2": {"k3": "str", "k4": [{"k6": 55}]}, "some": 42}, "s": "bar"}');
|
|
|
|
SELECT toTypeName(data), toTypeName(flattenTuple(data)) FROM t_flatten_object LIMIT 1;
|
|
SELECT untuple(flattenTuple(data)) FROM t_flatten_object ORDER BY data.id;
|
|
|
|
DROP TABLE IF EXISTS t_flatten_tuple;
|
|
DROP TABLE IF EXISTS t_flatten_object;
|