解析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

相关文章

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

C++ 多态性实战之何时使用 virtual 和 override的问题解析

《C++多态性实战之何时使用virtual和override的问题解析》在面向对象编程中,多态是一个核心概念,很多开发者在遇到override编译错误时,不清楚是否需要将基类函数声明为virt... 目录C++ 多态性实战:何时使用 virtual 和 override?引言问题场景判断是否需要多态的三个关

golang实现nacos获取配置和服务注册-支持集群详解

《golang实现nacos获取配置和服务注册-支持集群详解》文章介绍了如何在Go语言中使用Nacos获取配置和服务注册,支持集群初始化,客户端结构体中的IpAddresses可以配置多个地址,新客户... 目录golang nacos获取配置和服务注册-支持集群初始化客户端可选参数配置new一个客户端 支

Springboot主配置文件解析

《Springboot主配置文件解析》SpringBoot主配置文件application.yml支持多种核心值类型,包括字符串、数字、布尔值等,文章详细介绍了Profile环境配置和加载位置,本文... 目录Profile环境配置配置文件加载位置Springboot主配置文件 application.ym

MySQL 中的 JSON_CONTAIN用法示例详解

《MySQL中的JSON_CONTAIN用法示例详解》JSON_CONTAINS函数用于检查一个JSON文档中是否包含另一个JSON文档,这篇文章给大家介绍JSON_CONTAINS的用法、语法、... 目录深入了解 mysql 中的 jsON_CONTAINS1. JSON_CONTAINS 函数的概述2

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node