需求
数据库中有个字段存取的接口返回的JSON数据,现在需要取出JSON数据中部分信息,数据格式如下,要取出orderSn对应的数据
{ "data" : { "orderSn" : "D21031315340867693" , "payUrl" : "https://..." , "cOrderSnMap" : { "年夜饭礼盒" : "WD211414589349" } } , "success" : true , "totalCount" : 0 }
方法一:使用SUBSTRING_INDEX
1.格式:
SUBSTRING_INDEX(str, delimiter, number)
2.详细解释
返回从字符串 str 的第 number 个出现的分隔符 即delimiter 之后的字符串。
如果 number 是正数,则返回从str左边开始计数的第 number 个delimiter(不包含delimiter)左边的字符串。
如果 number 是负数,则返回从str右边开始计数的第(number 的绝对值)个delimiter(不包含delimiter)右边的字符串。
SELECT SUBSTRING_INDEX ('a*b' ,'*' ,1 ) -- 结果a
SELECT SUBSTRING_INDEX ('a*b' ,'*' ,-1 ) -- 结果b
SELECT SUBSTRING_INDEX (SUBSTRING_INDEX('a*b*c*d*e' ,'*' ,3 ),'*' ,-1 ) -- 结果c 。SUBSTRING_INDEX ('a*b*c*d*e' ,'*' ,3 )的结果是a *b *c
3.所以可以这样操作
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(result ,'"' ,6 ),'"' ,-1 );
result 就是上面示例的JSON,得出的结果就是D21031315340867693
方法二:使用SUBSTR或者SUBSTRING,前提是orderSn的值长度一致
1.格式
SUBSTR (str, start, length)
SUBSTRING (str, start, length)
2.详细解释
从字符串 str 的 start 位置(包含start 位置)截取长度为 length 的子字符串
3.具体的操作
SELECT SUBSTR(result ,21 ,18 ) ;
SELECT SUBSTRING (result ,21 ,18 ) ;
result 就是上面示例的JSON,上述两个的结果也都是D21031315340867693
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
2020-02-20 解决HttpServletRequest的输入流只能读取一次的问题