mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-13 18:02:24 +00:00
6ae4d29180
Signed-off-by: Azat Khuzhin <a.khuzhin@semrush.com>
113 lines
4.3 KiB
SQL
113 lines
4.3 KiB
SQL
-- Tags: no-parallel
|
|
|
|
set mutations_sync = 2;
|
|
|
|
-- system.parts has server default, timezone cannot be randomized
|
|
set session_timezone = '';
|
|
|
|
drop table if exists ttl;
|
|
|
|
create table ttl (d Date, a Int) engine = MergeTree order by a partition by toDayOfMonth(d)
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
insert into ttl values (toDateTime('2000-10-10 00:00:00'), 1);
|
|
insert into ttl values (toDateTime('2000-10-10 00:00:00'), 2);
|
|
insert into ttl values (toDateTime('2100-10-10 00:00:00'), 3);
|
|
insert into ttl values (toDateTime('2100-10-10 00:00:00'), 4);
|
|
|
|
|
|
alter table ttl modify ttl d + interval 1 day;
|
|
select * from ttl order by a;
|
|
select delete_ttl_info_min, delete_ttl_info_max from system.parts where database = currentDatabase() and table = 'ttl' and active > 0 order by name asc;
|
|
optimize table ttl final;
|
|
select * from ttl order by a;
|
|
select '=============';
|
|
|
|
drop table if exists ttl;
|
|
|
|
create table ttl (i Int, s String) engine = MergeTree order by i
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
insert into ttl values (1, 'a') (2, 'b') (3, 'c') (4, 'd');
|
|
|
|
alter table ttl modify ttl i % 2 = 0 ? toDate('2000-01-01') : toDate('2100-01-01');
|
|
select * from ttl order by i;
|
|
select delete_ttl_info_min, delete_ttl_info_max from system.parts where database = currentDatabase() and table = 'ttl' and active > 0;
|
|
optimize table ttl final;
|
|
select * from ttl order by i;
|
|
select '=============';
|
|
|
|
alter table ttl modify ttl toDate('2000-01-01');
|
|
select * from ttl order by i;
|
|
select delete_ttl_info_min, delete_ttl_info_max from system.parts where database = currentDatabase() and table = 'ttl' and active > 0;
|
|
optimize table ttl final;
|
|
select * from ttl order by i;
|
|
select '=============';
|
|
|
|
drop table if exists ttl;
|
|
|
|
create table ttl (i Int, s String) engine = MergeTree order by i
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
insert into ttl values (1, 'a') (2, 'b') (3, 'c') (4, 'd');
|
|
|
|
alter table ttl modify column s String ttl i % 2 = 0 ? today() - 10 : toDate('2100-01-01');
|
|
select * from ttl order by i;
|
|
optimize table ttl final;
|
|
select * from ttl order by i;
|
|
select '=============';
|
|
|
|
alter table ttl modify column s String ttl toDate('2000-01-01');
|
|
select * from ttl order by i;
|
|
optimize table ttl final;
|
|
select * from ttl order by i;
|
|
select '=============';
|
|
|
|
drop table if exists ttl;
|
|
|
|
create table ttl (d Date, i Int, s String) engine = MergeTree order by i
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
insert into ttl values (toDate('2000-01-02'), 1, 'a') (toDate('2000-01-03'), 2, 'b') (toDate('2080-01-01'), 3, 'c') (toDate('2080-01-03'), 4, 'd');
|
|
|
|
alter table ttl modify ttl i % 3 = 0 ? toDate('2000-01-01') : toDate('2100-01-01');
|
|
select i, s from ttl order by i;
|
|
select delete_ttl_info_min, delete_ttl_info_max from system.parts where database = currentDatabase() and table = 'ttl' and active > 0;
|
|
optimize table ttl final;
|
|
select i, s from ttl order by i;
|
|
select '=============';
|
|
|
|
alter table ttl modify column s String ttl d + interval 1 month;
|
|
select i, s from ttl order by i;
|
|
optimize table ttl final;
|
|
select i, s from ttl order by i;
|
|
select '=============';
|
|
|
|
drop table if exists ttl;
|
|
|
|
create table ttl (i Int, s String, t String) engine = MergeTree order by i
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
insert into ttl values (1, 'a', 'aa') (2, 'b', 'bb') (3, 'c', 'cc') (4, 'd', 'dd');
|
|
|
|
alter table ttl modify column s String ttl i % 3 = 0 ? today() - 10 : toDate('2100-01-01'),
|
|
modify column t String ttl i % 3 = 1 ? today() - 10 : toDate('2100-01-01');
|
|
|
|
select i, s, t from ttl order by i;
|
|
optimize table ttl final;
|
|
select i, s, t from ttl order by i;
|
|
-- MATERIALIZE TTL ran only once
|
|
select count() from system.mutations where database = currentDatabase() and table = 'ttl' and is_done;
|
|
select '=============';
|
|
|
|
drop table if exists ttl;
|
|
|
|
-- Nothing changed, don't run mutation
|
|
create table ttl (i Int, s String ttl toDate('2000-01-02')) engine = MergeTree order by i
|
|
SETTINGS max_number_of_merges_with_ttl_in_pool=0,materialize_ttl_recalculate_only=true;
|
|
|
|
alter table ttl modify column s String ttl toDate('2000-01-02');
|
|
select count() from system.mutations where database = currentDatabase() and table = 'ttl' and is_done;
|
|
|
|
drop table if exists ttl;
|