ClickHouse查看数据库、表、列等元数据信息

ClickHouse提供系统表查询数据库的状态,包括服务器环境、数据库信息、表信息、列信息、函数、配置等信息。系统表位于system数据库中,仅可用于读取数据,大多数系统表数据会加载到内存中。CK提供的系统表主要包括:

  • system.tables:包含数据库中所有表的信息,如表名、引擎类型、创建时间等。
  • system.columns:包含每个表的列信息,如列名、数据类型、缺省值等。
  • system.databases:包含所有数据库信息,如库名、引擎类型、数据路径等。
  • system.functions:包含所有有效函数信息,如名称、参数、返回值等。
  • system.parts:包含每个表的分片信息,如位置、大小、分区键等。
  • system.settings:该表包含所有配置信息,如配置名称、数据类型、缺省值等。

使用举例如下:

sql 复制代码
SELECT * FROM system.tables LIMIT 2; -- 查询表信息
-- 查询列信息
SELECT database, table, name, type, position
FROM system.columns
WHERE table_name = 'my_table';
-- 查询特定分片的位置和大小
SELECT partition_id, path, rows
FROM system.parts
WHERE table_name = 'my_table' AND partition_id = 1;

-- 查询配置信息
SELECT name, value, default, description
FROM system.settings
WHERE name = 'max_threads'

另外,ClickHouse也提供了兼容SQL标准的information_schema系统数据库,用于查看数据库对象的元数据。该数据库可以理解成虚拟库,它提供了查询元数据的视图,比如:

sql 复制代码
SHOW TABLES FROM INFORMATION_SCHEMA; -- 查看提供了哪些视图
SELECT * FROM INFORMATION_SCHEMA.TABLES; -- 查看表信息
-- 查看列信息
SELECT * FROM INFORMATION_SCHEMA.COLUMNS
WHERE (table_schema = currentDatabase() OR table_schema = '')
  AND table_name NOT LIKE '%inner%' 
LIMIT 1 
FORMAT Vertical;

在内部实现方面,INFORMATION_SCHEMA中的视图通常映射到普通系统表,如system.columns、system.tables等。因此,建议使用时选择ClickHouse的原生system系统库,因为system更原生、更丰富、更底层。可以查看更多元数据信息。需要规范和标准化(比如适配更多数据库)时可选择INFORMATION_SCHEMA库。

相关推荐
麦兜和小可的舅舅14 小时前
ClickHouse 一次Schema修改造成的Merge阻塞问题的分析和解决过程
clickhouse
Aloudata2 天前
数据治理选型对比:Apache Atlas vs 商业平台在存储过程解析与自动化治理的实测分析
数据挖掘·自动化·apache·元数据·数据血缘
Aloudata2 天前
金融数据治理新范式:如何用算子级血缘与主动元数据 10分 钟定位 EAST 报送异常?
金融·数据治理·元数据·noetl·数据血缘
Aloudata3 天前
破解监管溯源难题:从表级血缘到算子级血缘的数据治理升级
数据库·数据挖掘·数据治理·元数据·数据血缘
bigdata-rookie4 天前
StarRocks(2.5.1)vs Clickhouse(21.7.3.14)集群 SSB 性能测试
clickhouse
CTO Plus技术服务中4 天前
ClickHouse原理解析与应用实践教程
clickhouse
Aloudata6 天前
告别 90% 误报率:基于算子级血缘实现精准数据治理与变更影响分析
数据挖掘·数据治理·元数据·数据血缘
zhangyifang_0096 天前
ClickHouse查询报错:Code: 62. DB::Exception: Max query size exceeded:
数据库·clickhouse
HideInTime6 天前
Clickhouse进阶分组复合排序查询
clickhouse
memgLIFE7 天前
clickhouse
clickhouse