mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-30 03:22:14 +00:00
209 lines
13 KiB
SQL
209 lines
13 KiB
SQL
-- Tags: no-parallel
|
|
|
|
set allow_deprecated_syntax_for_merge_tree=1;
|
|
set optimize_on_insert = 0;
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, version, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 4 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 4 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 0, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 1, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 5 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 5 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date, value), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 1000000;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 1000000;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value UInt64, key UInt64, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(date, (date), 8192, sign, version);
|
|
insert into mult_tab select '2018-01-31', number, number, 0, if(number < 64, 1, -1) from system.numbers limit 128;
|
|
insert into mult_tab select '2018-01-31', number, number + 128, 0, if(number < 64, -1, 1) from system.numbers limit 128;
|
|
select 'table with 2 blocks final';
|
|
select date, value, version, sign from mult_tab final order by date, key, sign settings max_block_size=33;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select date, value, version, sign from mult_tab;
|
|
|
|
select '-------------------------';
|
|
select 'Vertival merge';
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, version, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
select 'table with 4 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 4 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 0, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 1, 1, -1) from system.numbers limit 10;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 1, if(number % 3 = 2, 1, -1) from system.numbers limit 10;
|
|
select 'table with 5 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 5 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value String, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date, value) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, 1, -1) from system.numbers limit 1000000;
|
|
insert into mult_tab select '2018-01-31', 'str_' || toString(number), 0, if(number % 2, -1, 1) from system.numbers limit 1000000;
|
|
select 'table with 2 blocks final';
|
|
select * from mult_tab final order by date, value, sign;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select * from mult_tab;
|
|
|
|
select '-------------------------';
|
|
|
|
drop table if exists mult_tab;
|
|
create table mult_tab (date Date, value UInt64, key UInt64, version UInt64, sign Int8) engine = VersionedCollapsingMergeTree(sign, version) order by (date) settings enable_vertical_merge_algorithm = 1, vertical_merge_algorithm_min_rows_to_activate = 1, vertical_merge_algorithm_min_columns_to_activate = 0;
|
|
insert into mult_tab select '2018-01-31', number, number, 0, if(number < 64, 1, -1) from system.numbers limit 128;
|
|
insert into mult_tab select '2018-01-31', number, number + 128, 0, if(number < 64, -1, 1) from system.numbers limit 128;
|
|
select 'table with 2 blocks final';
|
|
select date, value, version, sign from mult_tab final order by date, key, sign settings max_block_size=33;
|
|
optimize table mult_tab;
|
|
select 'table with 2 blocks optimized';
|
|
select date, value, version, sign from mult_tab;
|
|
|
|
DROP TABLE mult_tab;
|