clickhouse 使用global in 优化 in查询

文章目录

      • in例子
      • [使用global in](#使用global in)

in例子

bash 复制代码
SELECT uniq(UserID) FROM distributed_table
WHERE CounterID = 101500 
AND UserID IN (SELECT UserID FROM distributed_table WHERE CounterID = 34)

对于in 查询来说,本来查询的就是分布式表,假设这个表有100 个分片,in 查询就要查询100次,再加上外面也是查的分布式表,那就是100*100 次

bash 复制代码
SELECT UserID FROM distributed_table WHERE CounterID = 34

使用global in

bash 复制代码
SELECT uniq(UserID) FROM distributed_table
WHERE CounterID = 101500 
AND UserID  global IN (SELECT UserID FROM distributed_table WHERE CounterID = 34)

global in 实现

ClickHouse 会从右表的所有分片中读取完整数据,然后收集到的右表数据会被广播到查询涉及的每个分片上。

相当于右表里的只查询一次,大大减少处理时间

相关推荐
qq_356408662 天前
clickhouse写分布式表,等一段时间才能看到数据。
分布式·clickhouse
Jerelli2 天前
clickhouse Cannot execute replicated DDL query, maximum retries exceeded报错解决
clickhouse
qq_356408662 天前
clickhouse query_log 常用查询语句
数据库·clickhouse
PersistJiao2 天前
Couchbase、ClickHouse 和 Apache Doris在架构、功能、应用场景等方面的详细对比
clickhouse·架构·doris·couchbase
沙滩de流沙3 天前
ClickHouse
数据库·clickhouse
大饼酥4 天前
保姆级教程Docker部署ClickHouse镜像
clickhouse·docker·容器
cbigchaos4 天前
ClickHouse 日常操作记录
服务器·数据库·clickhouse
讓丄帝愛伱4 天前
Clickhouse使用基础
clickhouse
广而不精zhu小白4 天前
CentOS Stream 9 搭建单机版Clickhouse
linux·clickhouse·centos
广而不精zhu小白4 天前
CentOS Stream 9 搭建三节点Clickhouse集群
linux·clickhouse·centos