跳到主要内容
版本:Candidate-3.4

json_object

接收键值集合,并返回一个包含这些键值对的 JSON 类型的对象(以下简称JSON对象),并按照键的字典序排列。

语法

JSON_OBJECT(key, value, ...)

参数说明

  • key: JSON 对象的键。支持的数据类型为 VARCHAR。

  • value: JSON 对象的值。支持的数据类型为字符串型(STRING、VARCHAR、CHAR)、JSON、数字型(TINYINT、SMALLINT、INT、BIGINT、LARGEINT、DOUBLE、FLOAT)、BOOLEAN、以及NULL值。

返回值说明

返回一个JSON 对象。

如果参数keyvalue的总数为奇数,则最后一个字段的值会补为 null。

示例

示例一:构造一个由多种数据类型组成的 JSON 对象。

mysql> SELECT JSON_OBJECT('name', 'starrocks', 'active', true, 'published', 2020);
-> {"active": true, "name": "starrocks", "published": 2020}

示例二:构造一个多层嵌套的 JSON 对象。

mysql> SELECT JSON_OBJECT('k1', 1, 'k2', json_object('k2', 2), 'k3', json_array(4, 5));
-> {"k1": 1, "k2": {"k2": 2}, "k3": [4, 5]}

示例三:构造一个空的JSON对象。

mysql> SELECT JSON_OBJECT();
-> {}