解析json报文,获取key的value

2024-09-03 19:32
文章标签 json 解析 获取 key value 报文

本文主要是介绍解析json报文,获取key的value,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

新增解析json报文,获取key的value

建立如下两种类型

CREATE OR REPLACE TYPE ty_row_str_split  as object (strValue VARCHAR2 (4000));
CREATE OR REPLACE TYPE ty_tbl_str_split AS TABLE OF ty_row_str_split;

新建json截取通用方法

CREATE OR REPLACE FUNCTION fun_split(p_str       IN VARCHAR2,p_delimiter IN VARCHAR2)RETURN ty_tbl_str_split IS--名称:json截取通用方法--传入参数:--p_str json报文内容--p_delimiter json报文中的key值j         INT := 0;i         INT := 1;len       INT := 0;len1      INT := 0;str       VARCHAR2(4000);str_split ty_tbl_str_split := ty_tbl_str_split();
BEGIN--获取json长度lenlen  := LENGTH(p_str);--获取key长度len1len1 := LENGTH(p_delimiter);WHILE j < len LOOPj := INSTR(p_str, p_delimiter, i);IF j = 0 THENj   := len;str := SUBSTR(p_str, i);str_split.EXTEND;str_split(str_split.COUNT) := ty_row_str_split(strValue => str);IF i >= len THENEXIT;END IF;ELSEstr := SUBSTR(p_str, i, j - i);i   := j + len1;str_split.EXTEND;str_split(str_split.COUNT) := ty_row_str_split(strValue => str);END IF;END LOOP;RETURN str_split;
END fun_split;

解析json通用方法

create or replace FUNCTION fun_parsejson(p_jsonstr varchar2, p_key varchar2)RETURN VARCHAR2 AS--名称:解析json通用方法rtnVal    VARCHAR2(1000);i         NUMBER(2);jsonkey   VARCHAR2(500);jsonvalue VARCHAR2(1000);json      VARCHAR2(3000);
BEGINIF p_jsonstr IS NOT NULL THEN--将前后的括号去掉json := REPLACE(p_jsonstr, '{', '');json := REPLACE(json, '}', '');json := replace(json, '"', '');FOR temprow IN (SELECT strvalue AS VALUE FROM TABLE(fun_split(json, ','))) LOOPIF temprow.VALUE IS NOT NULL THENi         := 0;jsonkey   := '';jsonvalue := '';FOR tem2 IN (SELECT strvalue AS VALUEFROM TABLE(fun_split(temprow.value, ':'))) LOOPIF i = 0 THENjsonkey := tem2.VALUE;END IF;IF i = 1 THENjsonvalue := tem2.VALUE;END IF;i := i + 1;END LOOP;IF (jsonkey = p_key) THENrtnVal := jsonvalue;END if;END IF;END LOOP;END IF;RETURN rtnVal;
END fun_parsejson;

测试

--更新
update t_confirm_letter tset t.d_confirm_date = to_date(fun_parsejson(t.report_data, 'confirmDate'),'yyyy-MM-dd')where 1=1and t.d_confirm_date is nulland t.report_data is not null;

这篇关于解析json报文,获取key的value的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1133843

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

python中os.stat().st_size、os.path.getsize()获取文件大小

《python中os.stat().st_size、os.path.getsize()获取文件大小》本文介绍了使用os.stat()和os.path.getsize()函数获取文件大小,文中通过示例代... 目录一、os.stat().st_size二、os.path.getsize()三、函数封装一、os

Python中json文件和jsonl文件的区别小结

《Python中json文件和jsonl文件的区别小结》本文主要介绍了JSON和JSONL两种文件格式的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 众所周知,jsON 文件是使用php JSON(JavaScripythonpt Object No

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如