欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mysql 查询JSON结果的相关函数汇总

程序员文章站 2022-07-06 22:07:50
json 格式字段是 mysql 5.7 新加的属性,不够它本质上以字符串性质保存在库中的,刚接触时我只了解 $.xx 查询字段的方法,因为大部分时间,有这个就够了,其他交给程序就行了,但是最近一些操...

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,但是实际效果并非如此,列举几个例子

Mysql 查询JSON结果的相关函数汇总

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函数的资料请关注其它相关文章!

相关标签: MySQL json