clickhouse中Nullable与非空字段的建表与类型互转

本文探讨了在ClickHouse数据库中,如何安全地修改表字段的约束条件,包括从允许空值到不允许空值,反之亦然的过程。通过实例演示了Nullable类型字段与非空类型之间的转换条件及限制。

背景:有些表随着业务发展会涉及字段的约束修改 

1、历史数据字段容许为空 ,但现在要求不能为空了;

2、原类型不允许为空,但现在允许可以为空了。

drop table default.tttt
CREATE TABLE default.tttt(
id String,
name String
) ENGINE = MergeTree PARTITION BY id ORDER BY id SETTINGS index_granularity = 8192

尝试插入数据: 

insert into `default`.tttt values ('0',null)-- 失败

DB::Exception: Expression returns value NULL, that is out of range of type String, at: null) 

insert into `default`.tttt values ('1','name1'),('2','name2') --成功
select * from `default`.tttt


id|name |
--|-----|
2 |name2|
1 |name1|


尝试由Nullable转换成非空类型: 

alter table `default`.tttt MODIFY COLUMN name Nullable(String) --成功

插入一个空值,用于后面的测试: 

insert into `default`.tttt values ('3',null) --成功

 

select * from `default`.tttt


id|name |
--|-----|
2 |name2|
1 |name1|
3 |     |

再尝试由Nullable转换成非空类型:

alter table `default`.tttt MODIFY COLUMN name String  --失败,因为记录中存在null值


DB::Exception: Cannot convert NULL value to non-Nullable type (version 19.9.2.4 (official build))

CREATE TABLE default.tttt2(
id Nullable(String),
name Nullable(String)
) ENGINE = MergeTree PARTITION BY id ORDER BY id SETTINGS index_granularity = 8192

 创建失败,允许为空值不能用于排序 DB::Exception: Sorting key cannot contain nullable columns (version 19.9.2.4 (official build))

CREATE TABLE default.tttt2(
id String,
name Nullable(String)
) ENGINE = MergeTree PARTITION BY id ORDER BY id SETTINGS index_granularity = 8192
--成功
--直接用空表转换类型
alter table `default`.tttt2 MODIFY COLUMN name String --成功。


结论:

1、空表,Nullable与非空类型可以互转;

2、Nullable字段,如果记录不带有Null值,可以从Nullable转成非空类型;

3、含有null值的字段不允许转成非空类型;

4、Nullable字段不允许用于order by;

 


 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值