mysql contains函数_太实用了!JSON在Mysql中原来可以这么玩

本文介绍了一种解决因返回大数据量JSON字段导致的前端崩溃问题的方法,重点讲解了MySQL中的`json_extract`函数如何用于从JSON字段中提取数据,显著减少了返回给前端的数据大小。同时,还简要介绍了其他JSON处理函数如创建、修改、查询和转换等,为数据库中的JSON数据操作提供了实用技巧。
摘要由CSDN通过智能技术生成

26cae73a339d829258f1e3bc4a21cfd1.png

一、背景

最近接手做一个医疗项目,其中有一个需求是给病人做统计报表,其实这个之前是有过一版的,只是上到线上就立刻崩了。崩溃的原因也很简单,前端接受到数据量达到了400-500M,然后还要前端对这些数据进行处理、渲染,不卡死才怪。前端进行数据处理的原因是:当时后端工作量大,数据没有处理直接一骨碌全部返回给前端,而且前端页面需要显示不同的统计图和表格,数据的处理方式不一样。

了解了原因之后,就要查看具体的后端代码了。这是一个新上线的服务,按道理数据量不会很大。于是我进一步查看后台逻辑,其实关联的表也不过5张,数据条数也不超过5000条,这个数据量,按道理是不会崩溃才对,然后进一步查看,其中一张表存了一个report字段,字段类型为json,这个字段奇大无比,而且后端解析的逻辑也很多,解析好后,还要把这个字段返回给前端,重复了。来感受一下这个字段的恐惧吧,算了,太长了,还是放在本文的末尾吧,不然估计你都没兴趣看下面的正文的内容了,如果有兴趣的,可以翻到本文末尾来体会一下绝望吧。

二、解决办法

  1. 查看原需求文档,定位出报表需要用到的字段
  2. 第一个方案是将report字段分解,然后存到另外一张表,报表的时候再关联到这张分解好的表。但是这个需要一个定时任务来同步分解这个字段。后来查看mysql的文档看到了一个函数json_extract,简直可以完美解决我目前遇到的这问题。那张大表我是无力改了,和业务深度关联,费时费力。通过sql的手段直接减少绝大部分的数据量。
  3. 后端做报表数据分析处理,前端只需要渲染

三、json_extract的使用方法

  1. 获取value为非集合类型:统计报表中有一个体质,其中对应report字段中health_report.const_section.const_code,那么怎么截取出来呢?
SELECT 
    json_extract(json_extract(json_extract(r.report,"$.health_report"),"$.const_section"),"
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值