メインコンテンツまでスキップ
メインコンテンツまでスキップ

基本

注記

クライアントプロトコルのリファレンスは進行中です。

ほとんどの例はGoのみです。

このドキュメントは、ClickHouse TCPクライアントのバイナリプロトコルを説明します。

Varint

長さ、パケットコード、および他のケースでは unsigned varint エンコーディングが使用されます。 使用するには、binary.PutUvarint および binary.ReadUvarint

注記

Signed varintは使用されません。

文字列

可変長の文字列は (長さ、値) としてエンコードされます。ここで、長さvarint で、 はutf8文字列です。

参考

OOMを防ぐために長さを検証してください:

0 ≤ len < MAX

s := "Hello, world!"

// 文字列の長さをuvarintとして書き込みます。
buf := make([]byte, binary.MaxVarintLen64)
n := binary.PutUvarint(buf, uint64(len(s)))
buf = buf[:n]

// 文字列の値を書き込みます。
buf = append(buf, s...)
00000000  0d 48 65 6c 6c 6f 2c 20  77 6f 72 6c 64 21        |.Hello, world!|

整数

ヒント

ClickHouseは固定サイズ整数に リトルエンディアン を使用します。

Int32

v := int32(1000)

// エンコード。
buf := make([]byte, 8)
binary.LittleEndian.PutUint32(buf, uint32(v))

// デコード。
d := int32(binary.LittleEndian.Uint32(buf))
fmt.Println(d) // 1000
00000000  e8 03 00 00 00 00 00 00                           |........|

ブーリアン

ブーリアン値は1バイトで表現され、1true0false です。