ClickHouse常见的DDL语句

1.创建库

CREATE DATABASE IF NOT EXISTS mytestdb;

2.创建表

CREATE TABLE user_info
(
user_id UInt32 comment '用户标识',
name String comment '用户名',
create_date DateTime DEFAULT now() comment '创建时间',
sex Enum8('男' = 1, '女' = 2) comment '性别',
class_name LowCardinality(String) comment'班级名称',
phone Nullable(String) comment'手机号码'
)
ENGINE = MergeTree()
PRIMARY KEY (user_id, create_date);

常见表字段修饰符号
Nullable :表示字段可以为空。使用该修饰符后,字段的值可以为NULL。影响性能,索引不生效,一般不建议使用。
Default :指定字段的默认值。当插入数据时,如果没有为该字段提供值,则会使用默认值。
LowCardinality :用于高基数(唯一值很多)的列,使用字典编码来减少存储空间和提高查询性能。
Materialized :创建一个物化列,该列的值是通过计算其他列的表达式得到的。物化列的值在插入数据时计算,并在表中存储,以便在查询时快速访问。
Alias :为字段创建一个别名,可以在查询中使用别名来引用该字段。
Comment :为字段添加注释,用于描述字段的用途或其他相关信息。
Codec :指定字段的压缩编码方式,用于减少存储空间和提高查询性能。

这些修饰符可以单独使用,也可以组合在一起使用。例如:可以同时使用Nullable和Default修饰符来定义一个可为空且具有默认值的字段。

3.查看表结构

desc user_info;
show create table user_info;

4.重命名表及导入数据

rename table autorun_t_index to autorun_t_index_bak;

导入数据可以用insert xxx select xxx
insert into autorun_t_index select * from temp_autorun_t_index_bak;

5.ALTER语句

5.1ADD COLUMN(添加列)

语法
ADD COLUMN IF NOT EXISTS name type default_expr codec AFTER name_after

示例
ALTER TABLE user_info ADD COLUMN school_name String AFTER class_name;

5.2DROP COLUMN(删除列)

语法

DROP COLUMN IF EXISTS name

示例
ALTER TABLE user_info DROP COLUMN IF EXISTS school_name;

5.3CLEAR COLUMN(重置列的值)

语法

CLEAR COLUMN IF EXISTS name IN PARTITION partition_name

示例(分区不存在用tuple())
ALTER TABLE user_info CLEAR COLUMN school_name IN PARTITION tuple();

5.4COMMENT COLUMN(注释列说明)

语法

COMMENT COLUMN IF EXISTS name 'comment'

示例
ALTER TABLE user_info COMMENT COLUMN IF EXISTS school_name '学校名称';

5.5MODIFY COLUMN(修改类型/默认值/TTL)

语法

MODIFY COLUMN IF EXISTS name type default_expr TTL

示例
ALTER TABLE user_info MODIFY COLUMN school_name Array(String);

相关推荐
云天AI实战派16 分钟前
跨境出海全流程实战:用 Medusa + Hyperswitch + ClickHouse 搭建落地页、支付订阅、客服工单与多语言 SEO 闭环
大数据·人工智能·clickhouse·独立开发·跨境出海·medusa
海南java第二人1 天前
ClickHouse 实际应用类面试通关:项目案例、生产踩坑与实战经验
clickhouse·面试·实际应用类
meijinmeng2 天前
ClickHouse Kubernetes集群部署与维护文档
clickhouse
努力攻坚操作系统2 天前
ClickHouse详细教程
大数据·数据库·clickhouse
大帅点兵2 天前
设计一个金融交易监控系统
大数据·clickhouse·flink·spark·kafka·hbase
dinl_vin3 天前
FastAPI 系列 ·(十一):ClickHouse 集成——大数据查询实战
大数据·clickhouse·fastapi
麦兜和小可的舅舅4 天前
ClickHouse实时分布式集群设计方案选择探究
c++·分布式·clickhouse·kafka
海南java第二人5 天前
ClickHouse 性能优化完全指南:从数据模型到生产调优
clickhouse·性能优化
海南java第二人5 天前
ClickHouse 架构设计深度解析:分布式模型、高可用与选型对比
分布式·clickhouse·架构设计
l1t6 天前
DeepSeek总结的将 Rust Delta Kernel 集成到 ClickHouse
数据库·clickhouse·rust