微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

clickhouse中一列的最大长度是多少?可以修改吗?

如何解决clickhouse中一列的最大长度是多少?可以修改吗?

例如,Postgres 中列的最大长度为 63 个字符(如其官方文档中所述),类似地,clickhouse 表的最大列长度是多少以及是否可以更改它,如何?

解决方法

在 PostgreSQL 中,标识符——表名、列名、约束名等——被限制为最大长度为 63 个字节。

Clickhouse 对标识符长度没有自己的限制。但是您受到文件系统的限制,因为 CH 使用文件名作为表/列名。

Ext4 最大文件名长度 -- ext4 255 字节。并且最大路径为 4096 个字符。

https://serverfault.com/questions/9546/filename-length-limits-on-linux

问题在于 CH 使用 url-encode 对文件名进行编码。

create table "ляля"("тест" Int64) Engine = MergeTree order by tuple();
insert into "ляля" values(1);

/var/lib/clickhouse/data/dw/%D0%BB%D1%8F%D0%BB%D1%8F/

在这种情况下,4 个西里尔字符被存储为 24 个字节。

这会导致类似这样的各种问题

DB::ErrnoException: 无法打开文件 /var/lib/clickhouse/data/goSNynThCyuHpAZGJwCC/%D0%92%D1%8B%D0%B3%D1%80%D1%83%D0%B7%D0%BA %D0%B0%20%D0%B4%D0%BB%D1%8F%20%D0%B4%D0%B0%D1%88%D0%B1%D0%BE%D1%80%D0%B4%D0 %B8%D0%BD%D0%B3%D0%B0%2Etxt%281%29/tmp_insert_all_1_1_0/%D0%92%D1%8B%D0%B3%D1%80%D1%83%D0%B7%D0% BA%D0%B0%20%D0%B4%D0%BB%D1%8F%20%D0%B4%D0%B0%D1%88%D0%B1%D0%BE%D1%80%D0%B4% D0%B8%D0%BD%D0%B3%D0%B0%2Etxt%2E%D0%A0%D0%B5%D0%B3%D0%B8%D0%BE%D0%BD%D0%B0%D0% BB%D1%8C%D0%BD%D1%8B%D0%B9%20%D1%84%D0%B8%D0%BB%D0%B8%D0%B0%D0%BB.bin,错误号:36, strerror: 文件名太长

因此,我建议尽可能缩短标识符并仅使用拉丁字符。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。