メインコンテンツへスキップ
インポートに使用できるJSONフォーマットのほとんどは、エクスポートにも使用できます。最もよく使われるのは JSONEachRow です。
SELECT * FROM sometable FORMAT JSONEachRow
{"path":"Bob_Dolman","month":"2016-11-01","hits":245}
{"path":"1-krona","month":"2017-01-01","hits":4}
{"path":"Ahmadabad-e_Kalij-e_Sofla","month":"2017-01-01","hits":3}
また、JSONCompactEachRow を使用すると、カラム名を省略してディスク容量を節約できます。
SELECT * FROM sometable FORMAT JSONCompactEachRow
["Bob_Dolman", "2016-11-01", 245]
["1-krona", "2017-01-01", 4]
["Ahmadabad-e_Kalij-e_Sofla", "2017-01-01", 3]

データ型を文字列として扱う

ClickHouse はデータ型を考慮し、標準に従って JSON をエクスポートします。ただし、すべての値を文字列としてエンコードする必要がある場合は、JSONStringsEachRow フォーマットを使用できます。
SELECT * FROM sometable FORMAT JSONStringsEachRow
{"path":"Bob_Dolman","month":"2016-11-01","hits":"245"}
{"path":"1-krona","month":"2017-01-01","hits":"4"}
{"path":"Ahmadabad-e_Kalij-e_Sofla","month":"2017-01-01","hits":"3"}
これで、数値カラム hits は文字列としてエンコードされます。文字列としてのエクスポートは、すべての JSON* フォーマットでサポートされています。JSONStrings\* および JSONCompactStrings\* フォーマットを確認してください。
SELECT * FROM sometable FORMAT JSONCompactStringsEachRow
["Bob_Dolman", "2016-11-01", "245"]
["1-krona", "2017-01-01", "4"]
["Ahmadabad-e_Kalij-e_Sofla", "2017-01-01", "3"]

データとあわせてメタデータをエクスポートする

アプリケーションで広く使われている汎用的なJSONフォーマットでは、結果データだけでなく、カラムの型やクエリ統計もエクスポートされます。
SELECT * FROM sometable FORMAT JSON
{
        "meta":
        [
                {
                        "name": "path",
                        "type": "String"
                },
                ...
        ],

        "data":
        [
                {
                        "path": "Bob_Dolman",
                        "month": "2016-11-01",
                        "hits": 245
                },
                ...
        ],

        "rows": 3,

        "statistics":
        {
                "elapsed": 0.000497457,
                "rows_read": 3,
                "bytes_read": 87
        }
}
JSONCompact フォーマットでは、同じメタデータを出力しつつ、データ自体はよりコンパクトな形式で表現されます:
SELECT * FROM sometable FORMAT JSONCompact
{
        "meta":
        [
                {
                        "name": "path",
                        "type": "String"
                },
                ...
        ],

        "data":
        [
                ["Bob_Dolman", "2016-11-01", 245],
                ["1-krona", "2017-01-01", 4],
                ["Ahmadabad-e_Kalij-e_Sofla", "2017-01-01", 3]
        ],

        "rows": 3,

        "statistics":
        {
                "elapsed": 0.00074981,
                "rows_read": 3,
                "bytes_read": 87
        }
}
すべての値を文字列としてエンコードするには、JSONStrings または JSONCompactStrings フォーマットの利用を検討してください。

JSONデータとその構造をコンパクトにエクスポートする方法

データとその構造をより効率的に出力するには、JSONCompactEachRowWithNamesAndTypes フォーマットを使用します。
SELECT * FROM sometable FORMAT JSONCompactEachRowWithNamesAndTypes
["path", "month", "hits"]
["String", "Date", "UInt32"]
["Bob_Dolman", "2016-11-01", 245]
["1-krona", "2017-01-01", 4]
["Ahmadabad-e_Kalij-e_Sofla", "2017-01-01", 3]
これは、カラム名と型を示す 2 つのヘッダー行が先頭に付いた compact JSON フォーマットを使用します。このフォーマットは、別の ClickHouse インスタンス (または他のアプリ) にデータを取り込む際にも使用できます。

JSON をファイルにエクスポートする

エクスポートした JSON データをファイルに保存するには、INTO OUTFILE 句を使用します。
SELECT * FROM sometable INTO OUTFILE 'out.json' FORMAT JSONEachRow
36838935 rows in set. Elapsed: 2.220 sec. Processed 36.84 million rows, 1.27 GB (16.60 million rows/s., 572.47 MB/s.)
ClickHouse では、約 3,700 万件のレコードをわずか 2 秒で JSON ファイルにエクスポートできました。COMPRESSION 句を使用して、エクスポート時に圧縮を有効にすることもできます。
SELECT * FROM sometable INTO OUTFILE 'out.json.gz' FORMAT JSONEachRow
36838935 rows in set. Elapsed: 22.680 sec. Processed 36.84 million rows, 1.27 GB (1.62 million rows/s., 56.02 MB/s.)
完了までにより時間はかかりますが、生成される圧縮ファイルは大幅に小さくなります:
2.2G    out.json
576M    out.json.gz
最終更新日 2026年6月10日