--- sidebar_label: JSON title: JSON Type --- ## Syntax 1. Tag of JSON type ```sql create stable s1 (ts timestamp, v1 int) tags (info json); create table s1_1 using s1 tags ('{"k1": "v1"}'); ``` 2. -> Operator of JSON ```sql select * from s1 where info->'k1' = 'v1'; select info->'k1' from s1; ``` 3. contains Operator of JSON ```sql select * from s1 where info contains 'k2'; select * from s1 where info contains 'k1'; ``` ## Applicable Operations 1. When JSON data type is used in `where`, `match/nmatch/between and/like/and/or/is null/is no null` can be used but `in` can't be used. ```sql select * from s1 where info->'k1' match 'v*'; select * from s1 where info->'k1' like 'v%' and info contains 'k2'; select * from s1 where info is null; select * from s1 where info->'k1' is not null; ``` 2. Tag of JSON type can be used in `group by`, `order by`, `join`, `union all` and sub query, for example `group by json->'key'` 3. `Distinct` can be used with tag of JSON type ```sql select distinct info->'k1' from s1; ``` 4. Tag Operations The value of JSON tag can be altered. Please be noted that the full JSON will be override when doing this. The name of JSON tag can be altered. A tag of JSON type can't be added or removed. The column length of a JSON tag can't be changed. ## Other Restrictions - JSON type can only be used for tag. There can be only one tag of JSON type, and it's exclusive to any other types of tag. - The maximum length of keys in JSON is 256 bytes, and key must be printable ASCII characters. The maximum total length of a JSON is 4,096 bytes. - JSON format: - The input string for JSON can be empty, i.e. "", "\t", or NULL, but can't be non-NULL string, bool or array. - object can be {}, and the whole JSON is empty if so. Key can be "", and it's ignored if so. - value can be int, double, string, boll or NULL, can't be array. Nesting is not allowed, that means value can't be another JSON. - If one key occurs twice in JSON, only the first one is valid. - Escape characters are not allowed in JSON. - NULL is returned if querying a key that doesn't exist in JSON. - If a tag of JSON is the result of inner query, it can't be parsed and queried in the outer query. For example, below SQL statements are not supported. ```sql; select jtag->'key' from (select jtag from stable); select jtag->'key' from (select jtag from stable) where jtag->'key'>0; ```