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

json_keys

返回 JSON 对象中所有最上层成员 (key) 组成的数组。如果指定了path,则返回与path匹配的最上层成员组成的数组。

语法

json_keys(json_doc[, path])

参数说明

  • json_doc: JSON 字符串,必选。必须为 JSON 对象 (object)。

  • path:路径表达式,可选。取值类型为 VARCHAR。path 一般以 $ 符号作为开头;使用 . 作为路径分隔符;使用 [] 表示数组下标, 从 0 开始。

返回值说明

返回 JSON ARRAY 类型的值。

如果输入的 JSON 对象为空,则返回空数组。

如果json_doc不是 JSON 对象或者指定的路径不存在,则返回 NULL

如果json_doc为包含 JSON 对象的数组,可以使用path指向该对象,正常返回值,见示例五。

示例

示例一: JSON 对象为空对象,返回空数组。

SELECT JSON_KEYS('{}');
+-----------------+
| json_keys('{}') |
+-----------------+
| [] |
+-----------------+

示例二: 返回 JSON 对象的所有最上层 key 组成的数组。

SELECT JSON_KEYS('{"a": 1, "b": 2, "c": 3}');
+---------------------------------------+
| json_keys('{"a": 1, "b": 2, "c": 3}') |
+---------------------------------------+
| ["a", "b", "c"] |
+---------------------------------------+

示例三:返回指定路径下所有最上层 key 组成的数组。

SELECT JSON_KEYS('{"a": 1, "b": 2, "c": {"d": 3, "e": 4, "f": 5}}', '$.c');
+---------------------------------------------------------------------+
| json_keys('{"a": 1, "b": 2, "c": {"d": 3, "e": 4, "f": 5}}', '$.c') |
+---------------------------------------------------------------------+
| ["d", "e", "f"] |
+---------------------------------------------------------------------+

示例四:指定的路径不存在,返回 NULL。

SELECT JSON_KEYS('{"a": 1, "b": 2, "c": {"d": 3, "e": 4, "f": 5}}', '$.e');
+---------------------------------------------------------------------+
| json_keys('{"a": 1, "b": 2, "c": {"d": 3, "e": 4, "f": 5}}', '$.e') |
+---------------------------------------------------------------------+
| NULL |
+---------------------------------------------------------------------+

示例五:输入的字符串非 JSON 对象,且未指定path,返回 NULL。

SELECT JSON_KEYS('[1, 2, {"a": 1, "b": 2}]');
+---------------------------------------+
| json_keys('[1, 2, {"a": 1, "b": 2}]') |
+---------------------------------------+
| NULL |
+---------------------------------------+

示例六:输入的字符串为包含 JSON 对象的数组,且 JSON 对象与路径匹配,正常返回值。

SELECT JSON_KEYS('[0, 1, {"a": 1, "b": 2}]', '$[2]');
+-----------------------------------------------+
| json_keys('[0, 1, {"a": 1, "b": 2}]', '$[2]') |
+-----------------------------------------------+
| ["a", "b"] |
+-----------------------------------------------+