Mysql 查询JSON结果的相关函数汇总
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函数的资料请关注其它相关文章!
推荐阅读
-
Mysql将查询结果集转换为JSON数据的实例代码
-
Mysql 查询JSON结果的相关函数汇总
-
MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用
-
php怎么输出以下使用聚集函数和分组数据查询出来的MySQL查询结果?
-
诡异的问题——php函数不能输出mysql数据库查询结果?
-
关于对sql2000查询结果进行相关度排序的测试_MySQL
-
php查询mysql中的数据,并将结果返回为JSON格式,提取JSON中的数
-
php查询mysql中的数据,并将结果返回为JSON格式,提取JSON中的数
-
php怎么输出以下使用聚集函数和分组数据查询出来的MySQL查询结果?
-
Mysql有无groupby对max函数查询结果的影响ResultSet中有无记录受