mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-05 05:52:05 +00:00
45 lines
1.5 KiB
SQL
45 lines
1.5 KiB
SQL
-- { echo }
|
|
|
|
DROP TABLE IF EXISTS t_sparse;
|
|
DROP TABLE IF EXISTS t_sparse_1;
|
|
|
|
CREATE TABLE t_sparse (id UInt64, u UInt64, s String, arr1 Array(String), arr2 Array(UInt64))
|
|
ENGINE = MergeTree ORDER BY tuple()
|
|
SETTINGS ratio_of_defaults_for_sparse_serialization = 0.1;
|
|
|
|
INSERT INTO t_sparse SELECT
|
|
number,
|
|
if (number % 10 = 0, number, 0),
|
|
if (number % 5 = 0, toString(number), ''),
|
|
if (number % 7 = 0, arrayMap(x -> toString(x), range(number % 10)), []),
|
|
if (number % 12 = 0, range(number % 10), [])
|
|
FROM numbers (200);
|
|
|
|
SELECT column, serialization_kind FROM system.parts_columns
|
|
WHERE table = 't_sparse' AND database = currentDatabase()
|
|
ORDER BY column;
|
|
|
|
SELECT * FROM t_sparse WHERE u != 0 ORDER BY id;
|
|
SELECT * FROM t_sparse WHERE s != '' ORDER BY id;
|
|
SELECT * FROM t_sparse WHERE arr1 != [] ORDER BY id;
|
|
SELECT * FROM t_sparse WHERE arr2 != [] ORDER BY id;
|
|
|
|
SELECT sum(u) FROM t_sparse;
|
|
SELECT id % 7, sum(u) FROM t_sparse GROUP BY id % 7 ORDER BY id % 7;
|
|
|
|
SELECT arrayFilter(x -> x % 2 = 1, arr2) FROM t_sparse WHERE arr2 != [] LIMIT 5;
|
|
|
|
CREATE TABLE t_sparse_1 (id UInt64, v Int64)
|
|
ENGINE = MergeTree ORDER BY tuple()
|
|
SETTINGS ratio_of_defaults_for_sparse_serialization = 0;
|
|
|
|
INSERT INTO t_sparse_1 VALUES (1, 6), (2, 1), (3, 0), (4, -1), (5, 0), (6, 0), (7, -2), (8, 0), (9, 0), (10, 4), (11, 0);
|
|
|
|
SELECT * FROM t_sparse_1 ORDER BY v, id;
|
|
SELECT * FROM t_sparse_1 ORDER BY v DESC, id;
|
|
SELECT * FROM t_sparse_1 ORDER BY v, id LIMIT 5;
|
|
SELECT * FROM t_sparse_1 ORDER BY v DESC, id LIMIT 5;
|
|
|
|
DROP TABLE t_sparse;
|
|
DROP TABLE t_sparse_1;
|