clickhouse ReplacingMergeTree

ReplacingMergeTree

这个引擎可以删除重复的数据,但是不保证数据的绝对唯一。

设计之初是为了节约空间把相同的数据合并,不是为了做唯一校验。

而且合并行为是后天控制的,没有强唯一

建表写入

sql 复制代码
create table learning.ReplacingMergeTree_table(
   id UInt8,
   info String,
   timestamp DateTime
) engine = ReplacingMergeTree(timestamp)
order by id;
sql 复制代码
insert into learning.ReplacingMergeTree_table values (1,'js','2026-05-05 00:10:10');
insert into learning.ReplacingMergeTree_table values (1,'js','2026-05-04 00:10:10');
insert into learning.ReplacingMergeTree_table values (1,'js','2026-05-04 00:10:10');

查询后可以看到 数据不会直接合并

命令合并

为了演示强行执行合并命令

sql 复制代码
optimize table learning.ReplacingMergeTree_table final

执行完后可以看到 之保留了 timestamp 最大的那一条,因为我们设计的是 按照 timestamp 来去重 engine = ReplacingMergeTree(timestamp)

相关推荐
杉氧10 小时前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏11 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧11 小时前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄11 小时前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭12 小时前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景12 小时前
Kotlin Flow操作符学习
android·kotlin
plainGeekDev13 小时前
GreenDAO → Room
android·java·kotlin
weiggle14 小时前
第八篇:ViewModel + Compose——生产级状态管理实践
android
恋猫de小郭18 小时前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
plainGeekDev20 小时前
ButterKnife → ViewBinding
android·java·kotlin