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);

相关推荐
weixin_307779139 小时前
Linux下GCC和C++实现统计Clickhouse数据仓库指定表中各字段的空值、空字符串或零值比例
linux·运维·c++·数据仓库·clickhouse
斯特凡今天也很帅1 天前
clickhouse常用语句汇总——持续更新中
数据库·sql·clickhouse
SelectDB技术团队2 天前
从 ClickHouse、Druid、Kylin 到 Doris:网易云音乐 PB 级实时分析平台降本增效
大数据·数据仓库·clickhouse·kylin·实时分析
risc1234567 天前
【ClickHouse】RollingBitmap
clickhouse
斯特凡今天也很帅7 天前
clickhouse如何查看操作记录,从日志来查看写入是否成功
数据库·clickhouse
袖清暮雨12 天前
ClickHouse讲解
大数据·数据库·数据仓库·clickhouse·oracle
江枫渔火L14 天前
使用clickhouse的ReplacingMergeTree引擎表做活跃玩家信息表
数据库·clickhouse
潇凝子潇16 天前
Doris ClickHouse Greenplum 对比
clickhouse·doris·greenplum
递归尽头是星辰17 天前
ClickHouse核心优势分析与场景实战
大数据·数据仓库·clickhouse·实时分析·实时查询
鲁尼的小宝贝19 天前
基于Flink的数据中台管理平台
java·大数据·clickhouse·flink·yarn