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 会从右表的所有分片中读取完整数据,然后收集到的右表数据会被广播到查询涉及的每个分片上。

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

相关推荐
孤独天狼2 天前
ClickHosue
clickhouse
不吃饭的猪4 天前
clickhouse-20版本安装部署
数据库·mysql·clickhouse
lhyzws4 天前
CENTOS上的网络安全工具(三十五)Portainer Kafka-Clickhouse部署 Flink安装部署与编程
clickhouse·flink·kafka
一瓢西湖水6 天前
列式数据库-以clickHouse为例
数据库·clickhouse
zhglhy6 天前
ClickHouse高性能技术解析
clickhouse
恒悦sunsite9 天前
clickhouse之clickhouse-client命令简介和使用
clickhouse·client·列式数据库·客户端命令·ctyunos
言之。11 天前
Python调用DeepSeek API查询ClickHouse
windows·python·clickhouse
zhglhy12 天前
ckman将单节点ClickHouse转为集群方案
clickhouse·ckman
葡萄月令with蒲公英14 天前
使用clickhouse_connect从csv导入数据到clickhouse报错
clickhouse
韩金群16 天前
centos离线安装配置clickhouse
linux·clickhouse·centos