当前位置: 移动技术网 > IT编程>开发语言>JavaScript > Mysql 查询JSON结果的相关函数汇总

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

2020年11月13日  | 移动技术网IT编程  | 我要评论
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,但是实际效果并非如此,列举几个例子

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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网