slug: /zh/sql-reference/statements/alter/ttl sidebar_position: 44
sidebar_label: TTL
表的 TTL 操作 {#manipulations-with-table-ttl}
修改 MODIFY TTL {#modify-ttl}
你能修改 表 TTL ,命令语法如下所示:
ALTER TABLE table_name MODIFY TTL ttl_expression;
移除 REMOVE TTL {#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 │└───────────────────────┴─────────┴──────────────┘
更多参考
