数据仓库服务 GAUSSDB(DWS)-JSON类型:输入格式

时间:2024-04-18 16:25:02

输入格式

json和jsonb输入必须是一个符合JSON数据格式的字符串,此字符串用单引号''声明。

null (null-json):仅null,全小写。

1
2
SELECT 'null'::json;   -- suc
SELECT 'NULL'::jsonb;  -- err

数字 (num-json):正负整数、小数、0,支持科学计数法。

1
2
3
4
SELECT '1'::json;
SELECT '-1.5'::json;
SELECT '-1.5e-5'::jsonb, '-1.5e+2'::jsonb;
SELECT '001'::json, '+15'::json, 'NaN'::json;  -- 不支持多余的前导0,正数的+号,以及NaN和infinity。

布尔(bool-json):仅true、false,全小写。

1
2
SELECT 'true'::json;
SELECT 'false'::jsonb;  

字符串(str-json):必须是加双引号的字符串。

1
2
SELECT '"a"'::json;
SELECT '"abc"'::jsonb; 

数组(array-json):使用中括号[]包裹,满足数组书写条件。数组内元素类型可以是任意合法的JSON,且不要求类型一致。

1
2
3
SELECT '[1, 2, "foo", null]'::json;
SELECT '[]'::json;
SELECT '[1, 2, "foo", null, [[]], {}]'::jsonb; 

对象(object-json):使用大括号{}包裹,键必须是满足JSON字符串规则的字符串,值可以是任意合法的JSON。

1
2
3
SELECT '{}'::json;
SELECT '{"a": 1, "b": {"a": 2,  "b": null}}'::json;
SELECT '{"foo": [true, "bar"], "tags": {"a": 1, "b": null}}'::jsonb; 
support.huaweicloud.com/sqlreference-830-dws/dws_06_0020.html