跳转到主要内容

描述

RawBLOB 格式会将所有输入数据读入为单个值。它只能解析仅包含一个 String 类型字段或类似类型字段的表。 结果会以不带分隔符和转义的二进制格式输出。如果输出多个值,这种格式就会产生歧义,从而无法再将数据读回。

原始格式对比

下面比较 RawBLOBTabSeparatedRaw 格式。 RawBLOB:
  • 数据以二进制格式输出,不进行转义;
  • 值之间没有分隔符;
  • 每个值末尾都没有换行符。
TabSeparatedRaw:
  • 数据输出时不进行转义;
  • 每行包含由制表符分隔的值;
  • 每行最后一个值后都有换行符。
下面是 RawBLOBRowBinary 格式的对比。 RawBLOB:
  • 字符串字段输出时前面不带长度前缀。
RowBinary: 当向 RawBLOB 输入传入空数据时,ClickHouse 会抛出异常:
Code: 108. DB::Exception: No data to insert

使用示例

Query
$ clickhouse-client --query "CREATE TABLE {some_table} (a String) ENGINE = Memory;"
$ cat {filename} | clickhouse-client --query="INSERT INTO {some_table} FORMAT RawBLOB"
$ clickhouse-client --query "SELECT * FROM {some_table} FORMAT RawBLOB" | md5sum
Response
f9725a22f9191e064120d718e26862a9  -

格式设置

最后修改于 2026年6月10日