数据表的基本操作

简介: 数据表的基本操作

提示

目前只有 MergeTreeMergeDistributed 这三类表引擎支持 ALTER 查询。


追加新字段

假如需要对一张数据表追加新的字段,可以使用如下语法:

$ ALTER TABLE tb_name ADD COLUMN [IF NOT EXISTS] name [type] [default_expr] [AFTER name_after]点击复制复制失败已复制


例如,在数据表的末尾增加新字段:

$ ALTER TABLE testcol_v1 ADD COLUMN OS String DEFAULT 'mac';点击复制复制失败已复制


或是通过 AFTER 修饰符,在指定字段的后面增加新字段:

$ ALTER TABLE testcol_v1 ADD COLUMN IP String AFTER ID;点击复制复制失败已复制


对于数据表中已经存在的旧数据而言,新追加的字段会使用默认值补全。


修改数据类型

如果需要修改表字段的数据类型或者默认值,需要使用下面的语法:

$ ALTER TABLE tb_name MODIFY COLUMN [IF EXISTS] name [type] [default_expr]点击复制复制失败已复制


修改某个字段的数据类型,实质上会调用相应的 toType 转型方法。如果当前的类型与期望的类型不兼容,则修改操作将会失败。例如,将 String 类型的 IP 字段修改为 IPv4 类型是可行的:

$ ALTER TABLE testcol_v1 MODIFY COLUMN IP IPv4;点击复制复制失败已复制


而尝试将 String 类型转换为 UInt 类型就会出现错误:

$ ALTER TABLE testcol_v1 MODIFY COLUMN OS UInt32;
DB::Exception: Cannot parse string 'mac' as UInt32: syntax error at begin of string.点击复制复制失败已复制


修改备注

做好信息备注是保持良好编程习惯的美德之一,追加备注的语法如下所示:

$ ALTER TABLE tb_name COMMENT COLUMN [IF EXISTS] name 'some comment';点击复制复制失败已复制


例如,为 ID 字段增加备注:

$ ALTER TABLE testcol_v1 COMMENT COLUMN ID '主键ID';点击复制复制失败已复制


使用 DESC 查询可以看到上述增加备注的操作已经生效:

$ DESC testcol_v1;
┌─name─┬─type──┬─default_type─┬─default_expression─┬─comment─┬─codec_expression─┬─ttl_expression─┐
│ ID   │ Int32 │              │                    │ 主键ID  │                  │                │
└──────┴───────┴──────────────┴────────────────────┴─────────┴──────────────────┴────────────────┘点击复制复制失败已复制


删除已有字段

假如要删除某个字段,可以使用下面的语句:

$ ALTER TABLE tb_name DROP COLUMN [IF EXISTS] name点击复制复制失败已复制


例如,执行下面的语句删除 URL 字段:

$ ALTER TABLE testcol_v1 DROP COLUMN URL点击复制复制失败已复制


上述列字段在被删除之后,它的数据也会被连带删除。进一步来到 testcol_v1 的数据目录查验,会发现 URL 的数据文件已经被删除了:

# pwd
/chbase/data/data/default/testcol_v1/201907_2_2_0
# ll
total 56
-rw-r-----. 1 clickhouse clickhouse  28 Jul  2 21:02 EventTime.bin
-rw-r-----. 1 clickhouse clickhouse  30 Jul  2 21:02 ID.bin
-rw-r-----. 1 clickhouse clickhouse  30 Jul  2 21:02 IP.bin
-rw-r-----. 1 clickhouse clickhouse  30 Jul  2 21:02 OS.bin
省略…点击复制复制失败已复制


移动数据表

Linux 系统中, mv 命令的本意是将一个文件从原始位置 A 移动到目标位置 B ,但是如果位置 A 与位置 B 相同,则可以变相实现重命名的作用。 ClickHouseRENAME 查询就与之有异曲同工之妙, RENAME 语句的完整语法如下所示:

$ RENAME TABLE [db_name11.]tb_name11 TO [db_name12.]tb_name12, [db_name21.]tb_name21 TO [db_name22.]tb_name22 ...点击复制复制失败已复制


RENAME 可以修改数据表的名称,如果将原始数据库与目标数据库设为不同的名称,那么就可以实现数据表在两个数据库之间移动的效果。例如在下面的例子汇总 ,testcol_v1default 默认数据库被移动到了 db_test 数据库,同时数据表被重命名为 testcol_v2 :

$ RENAME TABLE default.testcol_v1 TO db_test.testcol_v2点击复制复制失败已复制


注意

数据表的移动只能在单个节点的范围内。换言之,数据表移动的目标数据库和原始数据库必须处在同一个服务节点内,而不能是集群中的远程节点。


清空数据表

假设需要将表内的数据全部清空,而不是直接删除这张表,则可以使用 TRUNCATE 语句,它的完整语法如下所示:

$ TRUNCATE TABLE [IF EXISTS] [db_name.]tb_name点击复制复制失败已复制


例如执行下面的语句,就能将 db_test.testcol_v2 的数据一次性清空:

$ TRUNCATE TABLE db_test.testcol_v2
目录
相关文章
|
SQL 关系型数据库 MySQL
MySQL数据库---库基本操作 以及 表结构的操作(DDL)
MySQL数据库---库基本操作 以及 表结构的操作(DDL)
117 3
|
7月前
|
关系型数据库 MySQL 数据库
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)
|
7月前
|
关系型数据库 MySQL 数据处理
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(下)
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(下)
|
7月前
|
SQL 前端开发 关系型数据库
MYSQL基础之【创建数据表,删除数据表】
MYSQL基础之【创建数据表,删除数据表】
63 0
|
SQL 关系型数据库 MySQL
MySQL数据库操作篇2(表的增删查改&约束)
MySQL数据库操作篇2(表的增删查改&约束)
106 0
|
SQL 关系型数据库 MySQL
|
关系型数据库 MySQL 数据库
mysql数据库中对数据的基本操作(二)
mysql数据库中对数据的基本操作(二)
mysql数据库中对数据的基本操作(二)
|
存储 关系型数据库 MySQL
MySql基础-笔记4 -数据表创建、删除和数据插入、查询等操作
MySql基础-笔记4 -数据表创建、删除和数据插入、查询等操作
132 0
MySql基础-笔记4 -数据表创建、删除和数据插入、查询等操作
|
SQL 关系型数据库 MySQL
MySQL基础-表操作~添加数据
DML英文全称是Data Manipulation Language(数据操作语言),用来对数据库中表的数据记录进 行增、删、改操作。
296 0
|
C# 数据库 C++
手把手教你使用C#操作SQLite数据库,新建数据库,创建表,插入,查询,删除,运算符,like(持续更新)
有问题欢迎留言!!!  目录: 一、新建项目,添加引用 二、创建数据库 三、创建表 四、插入数据  五、查询数据  六、删除数据  七、运算符 八、like语句 我的环境配置:windows 64,VS,SQLite(点击下载),System.Data.SQLite.DLL(点击下载)。
6992 1