json 格式字段是 mysql 5.7 新加的属性,不够它本质上以字符串性质保存在库中的,刚接触时我只了解 $.xx 查询字段的方法,因为大部分时间,有这个就够了,其他交给程序就行了,但是最近一些操作需要更复杂的查询操作,所以赶紧了解下更多的方法。
json_extract(json_doc [,path])
查询字段
mysql> set @j = '{"name":"wxnacy"}';
mysql> select json_extract(@j, '$.name');
+----------------------------+
| json_extract(@j, '$.name') |
+----------------------------+
| "wxnacy" |
+----------------------------+
还有一种更简洁的方式,但是只能在查询表时使用
mysql> select ext -> '$.name' from test; +-----------------+ | ext -> '$.name' | +-----------------+ | "wxnacy" | +-----------------+
在 $. 后可以正常的使用 json 格式获取数据方式,比如数组
mysql> set @j = '{"a": [1, 2]}';
mysql> select json_extract(@j, '$.a[0]');
+----------------------------+
| json_extract(@j, '$.a[0]') |
+----------------------------+
| 1 |
+----------------------------+
json_depth(json_doc)
计算 json 深度,计算方式 {} [] 有一个符号即为一层,符号下有数据增加一层,复杂 json 算到最深的一次为止,官方文档说 null 值深度为 0,但是实际效果并非如此,列举几个例子

json_length(json_doc [, path])
计算 json 最外层或者指定 path 的长度,标量的长度为1。数组的长度是数组元素的数量,对象的长度是对象成员的数量。
mysql> select json_length('[1, 2, {"a": 3}]');
+---------------------------------+
| json_length('[1, 2, {"a": 3}]') |
+---------------------------------+
| 3 |
+---------------------------------+
mysql> select json_length('{"a": 1, "b": {"c": 30}}');
+-----------------------------------------+
| json_length('{"a": 1, "b": {"c": 30}}') |
+-----------------------------------------+
| 2 |
+-----------------------------------------+
mysql> select json_length('{"a": 1, "b": {"c": 30}}', '$.b');
+------------------------------------------------+
| json_length('{"a": 1, "b": {"c": 30}}', '$.b') |
+------------------------------------------------+
| 1 |
+------------------------------------------------+
json_type(json_doc)
返回一个utf8mb4字符串,指示json值的类型。 这可以是对象,数组或标量类型,如下所示:
mysql> set @j = '{"a": [10, true]}';
mysql> select json_type(@j);
+---------------+
| json_type(@j) |
+---------------+
| object |
+---------------+
mysql> select json_type(json_extract(@j, '$.a'));
+------------------------------------+
| json_type(json_extract(@j, '$.a')) |
+------------------------------------+
| array |
+------------------------------------+
mysql> select json_type(json_extract(@j, '$.a[0]'));
+---------------------------------------+
| json_type(json_extract(@j, '$.a[0]')) |
+---------------------------------------+
| integer |
+---------------------------------------+
mysql> select json_type(json_extract(@j, '$.a[1]'));
+---------------------------------------+
| json_type(json_extract(@j, '$.a[1]')) |
+---------------------------------------+
| boolean |
+---------------------------------------+
可能的返回类型
纯json类型:
- object:json对象
- array:json数组
- boolean:json真假文字
- null:json null文字
数字类型:
- integer:mysql tinyint,smallint,mediumint以及int和bigint标量
- double:mysql double float标量
- decimal:mysql decimal和numeric标量
时间类型:
- datetime:mysql datetime和timestamp标量
- 日期:mysql date标量
- time:mysql time标量
字符串类型:
string:mysql utf8字符类型标量:char,varchar,text,enum和set
二进制类型:
blob:mysql二进制类型标量,包括binary,varbinary,blob和bit
所有其他类型:
opaque(原始位)
json_valid
返回0或1以指示值是否为有效json。 如果参数为null,则返回null。
mysql> select json_valid('{"a": 1}');
+------------------------+
| json_valid('{"a": 1}') |
+------------------------+
| 1 |
+------------------------+
mysql> select json_valid('hello'), json_valid('"hello"');
+---------------------+-----------------------+
| json_valid('hello') | json_valid('"hello"') |
+---------------------+-----------------------+
| 0 | 1 |
+---------------------+-----------------------+
以上就是mysql 查询json结果的相关函数汇总的详细内容,更多关于mysql json函数的资料请关注其它相关文章!
武得