Перейти к основному содержимому
Перейти к основному содержимому

JSONAsString

InputOutputAlias

Описание

В этом формате один объект JSON интерпретируется как одно значение. Если входные данные содержат несколько объектов JSON (разделенных запятыми), они интерпретируются как отдельные строки. Если входные данные заключены в квадратные скобки, они интерпретируются как массив объектов JSON.

примечание

Этот формат может быть разобран только для таблицы с единственным полем типа String. Остальные колонки должны быть установлены либо в DEFAULT, либо в MATERIALIZED, или могут быть опущены.

Как только вы сериализуете весь объект JSON в строку, вы можете использовать JSON функции для его обработки.

Пример использования

Основной пример

DROP TABLE IF EXISTS json_as_string;
CREATE TABLE json_as_string (json String) ENGINE = Memory;
INSERT INTO json_as_string (json) FORMAT JSONAsString {"foo":{"bar":{"x":"y"},"baz":1}},{},{"any json stucture":1}
SELECT * FROM json_as_string;
┌─json──────────────────────────────┐
│ {"foo":{"bar":{"x":"y"},"baz":1}} │
│ {}                                │
│ {"any json stucture":1}           │
└───────────────────────────────────┘

Массив объектов JSON

CREATE TABLE json_square_brackets (field String) ENGINE = Memory;
INSERT INTO json_square_brackets FORMAT JSONAsString [{"id": 1, "name": "name1"}, {"id": 2, "name": "name2"}];

SELECT * FROM json_square_brackets;
┌─field──────────────────────┐
│ {"id": 1, "name": "name1"} │
│ {"id": 2, "name": "name2"} │
└────────────────────────────┘

Настройки формата