Clickhouse 中列的最大长度是多少?可以修改吗?
What is the maximum length of a column in clickhouse? Can it be modified?
比如Postgres中一个column的最大长度是63个字符(官方文档有说明),同理一个clickhouse的column最大长度是多少table 如果可以更改,如何更改?
在 PostgreSQL 中,标识符 — table 名称、列名、约束名称等 — 最大长度限制为 63 字节.
Clickhouse 对标识符长度没有自己的限制。但是你受到文件系统限制的限制,因为 CH 使用文件名作为 table/column 名称。
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: 文件名太长
因此,我建议标识符尽可能短,并且只使用拉丁字符。
比如Postgres中一个column的最大长度是63个字符(官方文档有说明),同理一个clickhouse的column最大长度是多少table 如果可以更改,如何更改?
在 PostgreSQL 中,标识符 — table 名称、列名、约束名称等 — 最大长度限制为 63 字节.
Clickhouse 对标识符长度没有自己的限制。但是你受到文件系统限制的限制,因为 CH 使用文件名作为 table/column 名称。
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: 文件名太长
因此,我建议标识符尽可能短,并且只使用拉丁字符。