본문으로 바로가기
본문으로 바로가기

JSONAsObject

설명

이 형식에서는 단일 JSON 객체가 단일 JSON 값으로 해석됩니다. 입력에 쉼표로 구분된 여러 개의 JSON 객체가 포함되어 있으면, 각 객체는 별도의 행으로 해석됩니다. 입력 데이터가 대괄호로 둘러싸여 있으면 JSON 객체 배열로 해석됩니다.

이 형식은 하나의 JSON 유형 필드만 있는 테이블에 대해서만 파싱할 수 있습니다. 나머지 컬럼은 DEFAULT 또는 MATERIALIZED로 설정되어야 합니다.

사용 예

기본 예제

CREATE TABLE json_as_object (json JSON) ENGINE = Memory;
INSERT INTO json_as_object (json) FORMAT JSONAsObject {"foo":{"bar":{"x":"y"},"baz":1}},{},{"any json stucture":1}
SELECT * FROM json_as_object FORMAT JSONEachRow;
{"json":{"foo":{"bar":{"x":"y"},"baz":"1"}}}
{"json":{}}
{"json":{"any json stucture":"1"}}

JSON 객체 배열

CREATE TABLE json_square_brackets (field JSON) ENGINE = Memory;
INSERT INTO json_square_brackets FORMAT JSONAsObject [{"id": 1, "name": "name1"}, {"id": 2, "name": "name2"}];
SELECT * FROM json_square_brackets FORMAT JSONEachRow;
{"field":{"id":"1","name":"name1"}}
{"field":{"id":"2","name":"name2"}}

기본값을 가진 컬럼

CREATE TABLE json_as_object (json JSON, time DateTime MATERIALIZED now()) ENGINE = Memory;
INSERT INTO json_as_object (json) FORMAT JSONAsObject {"foo":{"bar":{"x":"y"},"baz":1}};
INSERT INTO json_as_object (json) FORMAT JSONAsObject {};
INSERT INTO json_as_object (json) FORMAT JSONAsObject {"any json stucture":1}
SELECT time, json FROM json_as_object FORMAT JSONEachRow
{"time":"2024-09-16 12:18:10","json":{}}
{"time":"2024-09-16 12:18:13","json":{"any json stucture":"1"}}
{"time":"2024-09-16 12:18:08","json":{"foo":{"bar":{"x":"y"},"baz":"1"}}}

형식 설정