ClickHouse/docs/zh/sql-reference/statements/alter/ttl.md

2.4 KiB

toc_priority toc_title
44 TTL

表的 TTL 操作

修改 MODIFY TTL

你能修改 表 TTL ,命令语法如下所示:

ALTER TABLE table_name MODIFY TTL ttl_expression;

移除 REMOVE TTL

TTL 属性可以用下列命令从表中移除:

ALTER TABLE table_name REMOVE TTL

示例

创建一个表,带有 TTL 属性如下所示:

CREATE TABLE table_with_ttl
(
    event_time DateTime,
    UserID UInt64,
    Comment String
)
ENGINE MergeTree()
ORDER BY tuple()
TTL event_time + INTERVAL 3 MONTH;
SETTINGS min_bytes_for_wide_part = 0;

INSERT INTO table_with_ttl VALUES (now(), 1, 'username1');

INSERT INTO table_with_ttl VALUES (now() - INTERVAL 4 MONTH, 2, 'username2');

运行命令 OPTIMIZE 强制清理 TTL:

OPTIMIZE TABLE table_with_ttl FINAL;
SELECT * FROM table_with_ttl FORMAT PrettyCompact;

第二行记录被从表中删除掉了.

┌─────────event_time────┬──UserID─┬─────Comment──┐
│   2020-12-11 12:44:57 │       1 │    username1 │
└───────────────────────┴─────────┴──────────────┘

现在用下面的命令,把表的 TTL 移除掉:

ALTER TABLE table_with_ttl REMOVE TTL;

重新插入上面的数据,并尝试再次运行 OPTIMIZE 命令清理 TTL 属性 :

INSERT INTO table_with_ttl VALUES (now() - INTERVAL 4 MONTH, 2, 'username2');
OPTIMIZE TABLE table_with_ttl FINAL;
SELECT * FROM table_with_ttl FORMAT PrettyCompact;

可以看得到 TTL 这个属性已经没了,并且可以看得到第二行记录并没有被删除:

┌─────────event_time────┬──UserID─┬─────Comment──┐
│   2020-12-11 12:44:57 │       1 │    username1 │
│   2020-08-11 12:44:57 │       2 │    username2 │
└───────────────────────┴─────────┴──────────────┘

更多参考