iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql使用函数json_extract处理Json类型数据的方法实例
  • 446
分享到

Mysql使用函数json_extract处理Json类型数据的方法实例

2024-04-02 19:04:59 446人浏览 泡泡鱼
摘要

目录1. 需求概述2. JSON_extract简介2.1 函数简介2.2 使用方式2.3 注意事项3. 实现验证3.1 建表查询3.2 查询结果总结 1. 需求概述 业务开发中通常Mysql数据库中某个字段会

1. 需求概述

业务开发中通常Mysql数据库中某个字段会需要存储json格式字符串,查询的时候有时json数据较大,每次全部取出再去解析查询效率较低,也比较麻烦,则mysql5.7版本提供提供函数json_extract,可以通过key查询value值,比较方便。

2. json_extract简介

2.1 函数简介

Mysql5.7版本以后新增的功能,Mysql提供了一个原生的Json类型,Json值将不再以字符串的形式存储,而是采用一种允许快速读取文本元素(document elements)的内部二进制(internal binary)格式。 在Json列插入或者更新的时候将会自动验证Json文本,未通过验证的文本将产生一个错误信息。 Json文本采用标准的创建方式,可以使用大多数的比较操作符进行比较操作,例如:=, <, <=, >, >=, <>, != 和 <=>。

2.2 使用方式

数据存储的数据是json字符串(类型是vachar)。

想要查询出来json中某个字段的值,用到方法是:JSON_EXTRACT()。

语法:

JSON_EXTRACT(json_doc, path[, path] …)

实际用法:

如果json字符串不是数组,则直接使用$.字段名即可

2.3 注意事项

JSON_EXTRACT性能验证 , 通过查看执行计划,验证全部都是全表扫描。

使用场景:数据量不大json字符串较大则可以采用,数据量较大不建议使用。

3. 实现验证

3.1 建表查询

-- 创建测试表
CREATE TABLE `tab_json` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `data` json DEFAULT NULL COMMENT 'json字符串',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- 新增数据
-- {"Tel": "132223232444", "name": "david", "address": "Beijing"}
-- {"Tel": "13390989765", "name": "Mike", "address": "Guangzhou"}
INSERT INTO `testdb`.`tab_json`(`id`, `data`) VALUES (1, '{\"Tel\": \"132223232444\", \"name\": \"david\", \"address\": \"Beijing\"}');
INSERT INTO `testdb`.`tab_json`(`id`, `data`) VALUES (2, '{\"Tel\": \"13390989765\", \"name\": \"Mike\", \"address\": \"Guangzhou\"}');
INSERT INTO `testdb`.`tab_json`(`id`, `data`) VALUES (3, '{"success": true,"code": "0","message": "","data": {"name": "jerry","age": "18","sex": "男"}}');
INSERT INTO `testdb`.`tab_json`(`id`, `data`) VALUES (4, '{"success": true,"code": "1","message": "","data": {"name": "tome","age": "30","sex": "女"}}');

-- 查询
select * from tab_json;

-- json_extract
select json_extract('{"name":"Zhaim","tel":"13240133388"}',"$.tel");
select json_extract('{"name":"Zhaim","tel":"13240133388"}',"$.name");

-- 对tab_json表使用json_extract函数
select json_extract(data,'$.name') from tab_json;

#如果查询没有的key,那么是可以查询,不过返回的是NULL.
select json_extract(data,'$.name'),json_extract(data,'$.Tel') from tab_json;  
select json_extract(data,'$.name'),json_extract(data,'$.tel') from tab_json;  
select json_extract(data,'$.name'),json_extract(data,'$.address') from tab_json;

-- 条件查询
select json_extract(data,'$.name'),json_extract(data,'$.Tel') from tab_json where json_extract(data,'$.name') = 'Mike';  

-- 嵌套json查询
select * from tab_json where json_extract(data,'$.success') = true;  
select json_extract(data,'$.data') from tab_json where json_extract(data,'$.success') = true;  
-- 查询data对应json中key为name的值
select json_extract( json_extract(data,'$.data'),'$.name') from tab_json where json_extract(data,'$.code') = "1";  
select json_extract( json_extract(data,'$.data'),'$.name'),json_extract( json_extract(data,'$.data'),'$.age') from tab_json where json_extract(data,'$.code') = "0";  

-- 性能验证 , 通过验证全部都是全表扫描,使用场景:数据量不大json字符串较大则可以采用,数据量较大不建议使用。
explain select * from tab_json where json_extract(data,'$.success') = true;  
explain select json_extract(data,'$.data') from tab_json where json_extract(data,'$.success') = true;  
-- 查询data对应json中key为name的值
explain select json_extract( json_extract(data,'$.data'),'$.name') from tab_json where json_extract(data,'$.code') = "1";  
explain select json_extract( json_extract(data,'$.data'),'$.name'),json_extract( json_extract(data,'$.data'),'$.age') from tab_json where json_extract(data,'$.code') = "0"; 

3.2 查询结果

Mysql使用函数json_extract处理Json类型数据的方法实例

Mysql使用函数json_extract处理Json类型数据的方法实例

总结 

到此这篇关于Mysql使用函数json_extract处理Json类型数据的文章就介绍到这了,更多相关Mysql用函数json_extract处理Json内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql使用函数json_extract处理Json类型数据的方法实例

本文链接: https://www.lsjlt.com/news/33967.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySql中怎么使用json_extract函数处理json字段
    这篇“MySql中怎么使用json_extract函数处理json字段”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySq...
    99+
    2023-06-30
  • MySql中的json_extract函数处理json字段详情
    目录前言1. 使用方式2. 使用演示3. 小结前言 在db中存储json格式的数据,相信大家都或多或少的使用过,那么在查询这个json结构中的数据时,有什么好的方法么?取出Strin...
    99+
    2024-04-02
  • MySql中使用JSON_TABLE 函数来实现json类型的数据查询
    使用 MySQL 8.0.4 及以上版本提供的 JSON_TABLE 函数来实现查询 id 在 3、4、5… 中的数据,示例如下: SELECT *FROM table_nameCROSS J...
    99+
    2023-10-06
    mysql json 数据库
  • MySQL数据库JSON类型的用法、意义、内置函数
    这篇文章主要讲解了“MySQL数据库JSON类型的用法、意义、内置函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库JSON类型的用法、意义...
    99+
    2024-04-02
  • mysql中json_extract的使用方法实例详解
    目录一、前言二、创建示例表三、基本语法- 获取jsON对象中某个key对应的value值- 获取JSON数组中某个元素- 获取JSON中的嵌套数据四、渐入佳境- 获取JSON多个路径的数据- 路径表达式*的使用- 返回N...
    99+
    2023-04-13
    mysql json_extract mysql json_extract 函数
  • 如何使用 PHP 函数处理 JSON 数据?
    php 提供了以下函数来处理 json 数据:解析 json 数据:使用 json_decode() 将 json 字符串转换为 php 数组。创建 json 数据:使用 json_en...
    99+
    2024-05-04
    php json 键值对
  • 处理不同数据类型的方法
    在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是Golang学习者,那么本文《处理不同数据类型的方法》就很适合你!本篇内容主要包括##content_title#...
    99+
    2024-04-04
  • JSON传递bool类型数据的处理方式介绍
    ajax中使用json传递数据时,其它数据类型都不是问题,但是如果服务器端生成的JSON中有bool类型的数据时,到客户端解析时出现了小小的问题,总结如下: 服务器返回的JSON为:...
    99+
    2022-11-15
    JSON传递bool bool类型数据
  • Oracle 处理json数据的方法
    目录备注:一. Json数据存储二. Json数据insert三. json数据update四. json数据查询五. 常用的json函数5.1 json_array5.2...
    99+
    2022-11-13
    Oracle 处理json数据 Oracle  json数据
  • Oracle 处理json数据的方法
    目录备注:一. json数据存储二. Json数据insert三. json数据update四. json数据查询五. 常用的json函数5.1 json_array5.2 JSON_ARRAYAGG5.3 J...
    99+
    2024-04-02
  • ​MySQL日期数据类型datetime的使用方法
    这篇文章将为大家详细讲解有关MySQL日期数据类型datetime的使用方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。MySQL日期数据类型datetime.date...
    99+
    2024-04-02
  • MySQL数值类型溢出的处理方法
    来,考考大家一个问题,在 MySQL 中当某一列设置为 int(0) 时会发生什么 ? 为了演示这个问题,我们先要创建一个表 DROP TABLE IF EXISTS `na`; CREATE TABL...
    99+
    2024-04-02
  • Mysql数字类型转换函数的方法
    小编给大家分享一下Mysql数字类型转换函数的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Mysql数字类型转换函数的方法...
    99+
    2024-04-02
  • 使用mybatisplus接收mysql字段为json类型的数据
    一.数据库设计 CREATE TABLE `inv_learning_examination_questions` ( `id` bigint(20) NOT NULL, `title` varchar(255) CHARA...
    99+
    2023-08-31
    sql 数据库
  • MySQL数据库的数据类型和基于MySQL数据类型的综合实例项目
    文章目录 MySQL数据库的数据类型和基于MySQL数据类型的综合实例项目1、MySQL具有的数据类型1.1、MySQL整数类型1.2、MySQL浮点类型和定点数1.3、MySQL日期与时间类...
    99+
    2023-09-02
    数据库 mysql MySQL数据库 MySQL数据库的应用 大数据
  • LEN函数适用于哪些数据类型的处理
    LEN函数是一种常用的函数,可用于获取字符串、列表、元组等类型数据的长度。下面将具体介绍LEN函数能够处理的数据类型,并提供相应的代码示例。 字符串(str):字符串是由若干个字符组成的序列,可以使用LEN函数获取字符串的长度。...
    99+
    2024-01-29
    列表 字符串 元组
  • Java多层嵌套JSON类型数据的方法
    本篇内容介绍了“Java多层嵌套JSON类型数据的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!多层嵌套JSON类型数据解析简单来说:“...
    99+
    2023-06-29
  • Golang函数的方法类型断言使用方法
    Golang是一种高效的编程语言,因其简洁、高效和可靠,目前广受欢迎。Golang中的函数和方法类型断言是高级程序员常用的重要工具之一。通过本文,我们将深入探讨Golang函数的方法类型断言的使用方法。方法类型断言简介在Golang中,方法...
    99+
    2023-05-16
    函数 Golang 方法类型断言
  • pytorch中函数tensor.numpy()的数据类型实例分析
    这篇文章主要讲解了“pytorch中函数tensor.numpy()的数据类型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“pytorch中函数tensor.numpy()的数据类型...
    99+
    2023-07-02
  • JavaScript数据类型使用实例分析
    这篇文章主要讲解了“JavaScript数据类型使用实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript数据类型使用实例分析”吧! ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作