网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
SELECT query_id,read_rows,total_rows_approx,memory_usage,initial_user,
initial_address,elapsed,query
FROM system.processes;
其中,字段含义如下:
query_id
:查询 ID。read_rows
:从表中读取的行数。total_rows_approx
:应读取的行总数的近似值。memory_usage
:请求使用的内存量。initial_user
:进行查询的用户。initial_address
:请求的 IP 地址。elapsed
:查询执行开始以来的秒数。query
:查询语句。
请注意,这只是一个基本示例,具体的查询可能会根据你的 ClickHouse 安装和配置而有所不同。你可以查阅 ClickHouse 的官方文档或系统表的定义来获取更准确的信息。
三、杀掉当前执行的SQL语句按查询唯一键
在 ClickHouse 中要杀掉当前执行的 SQL 语句,可以使用以下步骤:
- 执行以下 SQL 语句,查看正在执行的 SQL 语句的
query_id
:
SELECT query_id
FROM system.processes;
- 执行
KILL QUERY
命令,根据query_id
杀掉对应的 SQL 语句,语法如下:
KILL QUERY WHERE query_id = 'your\_query\_id';
其中,your_query_id
是你要杀掉的 SQL 语句的 query_id
。
请注意,ClickHouse 中的 query_id
会在查询执行完成后释放,因此在杀掉 SQL 语句后,对应的 query_id
可能会被其他查询使用。
四、查询某个表占用的硬盘空间
要查询 ClickHouse 中每个表占用的硬盘大小,可以使用以下 SQL 语句:
SELECT
database,
table,
formatReadableSize(sum(data_compressed_bytes) AS size) AS compressed,
formatReadableSize(sum(data_uncompressed_bytes) AS usize) AS uncompressed,
round(usize / size, 2) AS compr_rate,
sum(rows) AS rows,
count() AS part_count
FROM
system.parts
WHERE
(active = 1)
AND (database LIKE '数据库名称%')
AND (table LIKE '表名称%')
GROUP BY
database,
table
ORDER BY
size DESC;
该查询语句使用 system.parts
系统表,通过 WHERE
子句筛选出活动状态为 1
,并且数据库和表名匹配任意字符的记录。接着,使用 GROUP BY
子句按数据库和表名进行分组,然后使用聚合函数 sum
计算每个分组中数据压缩后的字节数 data_compressed_bytes
和未压缩的字节数 data_uncompressed_bytes
。最后,使用 formatReadableSize
函数将字节数转换为易读的大小表示,并计算压缩率 compr_rate
。结果将按照表大小降序排序。
请注意,这只是一个基本示例,具体的查询可能会根据你的 ClickHouse 安装和配置而有所不同。你可以查阅 ClickHouse 的官方文档或系统表的定义来获取更准确的信息。
五、查询某更新删除SQL语句是否执行成功
ClickHouse 中更新数据的语句是异步执行的,应用并不知道 ClickHouse 何时能更新数据,如果要做到强一致性,需要应用反查确认。可以通过下面的语句查询具体删除或更新操作的执行情况:
select database,table,mutation_id,command,create_time,block_numbers.number, is_done
from system.mutations
where table='表名';
其中,is_done
为1
表示执行完成。
ClickHouse 中system.mutations
表用于记录所有的mutations记录,其中关键字段is_done
,用于记录该mutation是否执行,0
表示未执行,1
表示已执行。其他字段的含义如下:
database
:数据库名称。table
:表名。mutation_id
:每次mutation操作的唯一标识符。command
:具体的mutation操作,如ALTER TABLE ... DELETE
或ALTER TABLE ... UPDATE
。create_time
:mutation操作的创建时间。block_numbers.number
:mutation操作所涉及的数据块数量。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
n.net/topics/618545628)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!