如何用SQL取出字段内是json体的数据

这篇具有很好参考价值的文章主要介绍了如何用SQL取出字段内是json体的数据。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据库中会遇到字段里面存的JSON结果的数据,那么如果我们想直接取到JSON里的值该怎么办呢?其实SQL自带的函数就可解决

未嵌套的Json取值

假如现在有表TableA,其中一个字段叫info,字段内容如下:

{"name":"zhangsan","age":28,"class":1}

使用JSON_EXTRACT()函数取出name的话,写法如下:

select JSON_EXTRACT(info, '$.name') from TableA;

但取值有一个问题,就是取出来如果是字符串,字符串的两边会带有双引号。那么如何去掉双引号?
使用JSON_UNQUOT()写法如下:

select JSON_UNQUOTE(JSON_EXTRACT(info, '$.name')) from TableA;

嵌套的Json取值

有嵌套JSON的话,只需要加“.”即可,比如有一个字段info,内容如下:

{"name":"zhangsan","age":28,"class":1,"other":{"book":"钢铁是怎样练成","music":"我记得"}}

要取出其他信息中歌曲名的话,如下面这样写:文章来源地址https://www.toymoban.com/news/detail-694233.html

select JSON_UNQUOTE(JSON_EXTRACT(info, '$.other.music')) from TableA;

到了这里,关于如何用SQL取出字段内是json体的数据的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SQL SERVER 中将数据表中的字段按分隔符分成多行多列

     SQL SERVER 中将数据表中的字段按分隔符分成多行多列_sql按逗号拆分列为多行_帅气的苹果果的博客-CSDN博客      

    2024年02月07日
    浏览(55)
  • 用bat 命令 修改sql文件中的数据库名字 新的名字通过读取配置文件中的字段获取

    在批处理脚本中,如果新数据库名存储在配置文件(比如config.ini)中的某个字段内,可以按照以下步骤进行: 假设你的配置文件内容如下: 要读取这个值并用于替换.sql文件中的旧数据库名,请使用以下批处理脚本: 在这个脚本中,首先通过 findstr 和 for /f 命令组合读取配置

    2024年02月02日
    浏览(65)
  • SQL中的替换函数replace将字段中的匹配值进行替换

    目录 一、更新替换 二、查询替换   一、更新替换 例:将user表中的address字段中IP1替换为IP2 二、查询替换

    2024年02月16日
    浏览(54)
  • sql server 求多个字段中的最小值和最大值

    程序代码园发文地址: sql server 求多个字段中的最小值和最大值-程序代码园 小说,Java,HTML,Java小工具,程序代码园,http://www.byqws.com/ ,sql server 求多个字段中的最小值和最大值 http://www.byqws.com/blog/2143.html      今天在工作中,遇到一个需求,需要把最近6个月的出库数据,去掉一个

    2024年01月20日
    浏览(53)
  • SQL Server创建数据表,新增字段的SQL语句

    1、创建数据库 语法:CREATE DATABASE 数据库名称 2、创建数据表  语法: USE suntest   create table 仓库   (   仓库编号 int ,    仓库号 varchar(50) ,    城市 varchar(50) ,    面积 int   )   create table 仓库1   (   仓库编号 int not null ,    仓库号 varchar(50) not null,    城市 varchar(50) not null

    2024年02月10日
    浏览(58)
  • 数据分析师如何用SQL解决业务问题?

    本文来自问答。 提问:数据分析人员需要掌握sql到什么程度? 请问做一名数据分析人员,在sql方面需要掌握到什么程度呢?会增删改查就可以了吗?还是说关于开发的内容也要会?不同阶段会有不同的要求吗? 正文: 作为专注数据分析结论/项目在业务落地以实现增长的分

    2024年02月14日
    浏览(57)
  • SQL中如何用快照,恢复被误删的数据?

    什么是快照 数据库快照是sql server 2005的一个新功能。MSDN上对它的定义是: 数据库快照是数据库(称为“源数据库”)的只读静态视图。在创建时,每个数据库快照在事务上都与源数据库一致。在创建数据库快照时,源数据库通常会有打开的事务。在快照可以使用之前,打开

    2024年02月13日
    浏览(44)
  • SQL中对数据字段null值的处理

    在我们平常的数据开发工作中,由于数据质量的问题或者是在数据关联的过程中,可能会出现字段内容为null值的情况,如果该字段需要展示或者是参与计算的话,怎么处理这些内容就很重要了,以下是我用到的SQL中对null值的处理,与大家分享。 hive里面对null值的处理用到的

    2024年02月09日
    浏览(46)
  • SQL Server修改数据字段名的方法

    1. ALTER TABLE语句修改 这是一种最常用的数据库更改字段的方法,使用Alter Table语句来更改数据库字段的名称。 一般格式如下: ALTER TABLE 表名 RENAME COLUMN 原字段名 TO 新字段名; 例如,修改字段名字段名从UserName到Uname: ALTER TABLE Users RENAME COLUMN UserName TO Uname 2. EXEC sp_RENAME存储过程

    2024年01月25日
    浏览(49)
  • 【Sql】根据字段分组排序,取其第一条数据

    (1)问题描述 有时候我们需要对数据进行去重处理,例如查询结果里的文件名有重复,我们希望可以按照创建时间排序,最终结果里每个文件名只取创建时间最近的一个。 (2)有哪些问题 想到去重,可以想到使用distinct或者group by分组。但是这两者有个问题,例如我们查询

    2024年02月16日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包