MySql中的json_extract函数处理json字段详情
前言
在db中存储json格式的数据,相信大家都或多或少的使用过,那么在查询这个json结构中的数据时,有什么好的方法么?取出String之后再代码中进行解析?
接下来本文将介绍一下Mysql5.7+之后提供的json_extract函数,可以通过key查询value值
1. 使用方式
数据存储的数据是json字符串,类型为我们常用的varchar即可
语法:
JSON_EXTRACT(json_doc, path[, path] …)
若json字符串非数组时,可以通过$.字段名
来表示查询对应的value
2. 使用演示
创建一个测试的表:
CREATE TABLE `json_table` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键id', `val` json DEFAULT NULL COMMENT 'json字符串', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
插入几条数据:
insert into `json_table` values (1, '{"name": "一灰灰blog", "age": 18}'); insert into `json_table` values (2, '{"name": "一灰灰blog", "site": "https://blog.hhui.top"}');
查询json串中的name
,如下:
mysql> select json_extract(`val`, '$.name') from `json_table`; +-------------------------------+ | json_extract(`val`, '$.name') | +-------------------------------+ | "一灰灰blog" | | "一灰灰blog" | +-------------------------------+
如果查询的key不在json串中,返回的是null,而不是抛异常
mysql> select json_extract(`val`, '$.name') as `name`, json_extract(`val`, '$.site') as `site` from `json_table`; +-----------------+-------------------------+ | name | site | +-----------------+-------------------------+ | "一灰灰blog" | NULL | | "一灰灰blog" | "https://blog.hhui.top" | +-----------------+-------------------------+
接下来再看一下如果为json数组,怎么整
mysql> insert into `json_table` values (3, '[{"name": "一灰灰", "site": "https://spring.hhui.top"}]'); mysql> select json_extract(`val`, '$[0].name') from `json_table` where id = 3; +----------------------------------+ | json_extract(`val`, '$[0].name') | +----------------------------------+ | "一灰灰" | +----------------------------------+
除了在查询结果中使用json_extract之外,也可以在查询条件中使用它
mysql> select * from `json_table` where json_extract(`val`, '$.name') = '一灰灰blog'; +----+------------------------------------------------------------+ | id | val | +----+------------------------------------------------------------+ | 1 | {"age": 18, "name": "一灰灰blog"} | | 2 | {"name": "一灰灰blog", "site": "https://blog.hhui.top"} | +----+------------------------------------------------------------+
3. 小结
json_extract函数的使用方法,用于解析字段内value为json串的场景
到此这篇关于MySql中的json_extract函数处理json字段详情的文章就介绍到这了,更多相关MySql 处理json 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
winxp 安装MYSQL 出现Error 1045 access denied 的解决方法
自己遇到了这个问题,也找了很久才解决,就整理一下,希望对大家有帮助!2010-07-07MySQL 时间类型用 datetime, timestamp 还是 integer 更好
这篇文章主要介绍了MySQL 时间类型用datetime,timestamp还是integer更好,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-09-09
最新评论