日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

oracle大对象实例_Oracle解析复杂json的方法实例详解

發(fā)布時(shí)間:2025/3/20 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle大对象实例_Oracle解析复杂json的方法实例详解 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

問(wèn)題背景:

當(dāng)前在Oracle數(shù)據(jù)庫(kù)(11G之前的版本)解析json沒(méi)有可以直接使用的系統(tǒng)方法,網(wǎng)上流傳的PLSQL腳本大多也只可以解析結(jié)構(gòu)較單一的json串,對(duì)于結(jié)構(gòu)復(fù)雜的json串還無(wú)法解析。如此一來(lái)導(dǎo)致即便可以在PL/SQL中調(diào)用遠(yuǎn)程接口,但返回結(jié)果仍需傳給前臺(tái)js或java等其它代碼進(jìn)行處理,不太方便。

分析思路:

1、在PL/SQL中寫json串,無(wú)需聲明json對(duì)象,只需直接拼接成格式正確的json字符串即可,因此數(shù)據(jù)庫(kù)對(duì)象間json串的傳遞完全可以用varchar2或clob來(lái)代替。

2、結(jié)構(gòu)復(fù)雜的json串節(jié)點(diǎn)元素值基本上可以分為兩類:①仍為json串②json數(shù)組,因此我們只需對(duì)這兩種類型的json對(duì)象進(jìn)行處理即可。

3、在PL/SQL中處理json數(shù)組時(shí),由于json元素是無(wú)序且可以重復(fù)的,因此我們需要對(duì)數(shù)組成員進(jìn)行索引并能夠獲取數(shù)組長(zhǎng)度才可以對(duì)其循環(huán)處理。

4、java中有很多可以方便解析json串的開(kāi)源jar包,且數(shù)據(jù)庫(kù)支持導(dǎo)入java類文件,因此是否可以將java代碼編譯生成的class導(dǎo)入數(shù)據(jù)處理json呢?

解決方案:

方法1:loadjava導(dǎo)入java類進(jìn)行解析

1、查看當(dāng)前數(shù)據(jù)庫(kù)已導(dǎo)入的java類文件

2、執(zhí)行l(wèi)oadjava命令導(dǎo)入處理json所需jar文件,在此選擇org.json而不選擇fastjson或jackson的原因是該jar包沒(méi)有外部依賴且滿足功能的同時(shí)所需導(dǎo)入類文件較少。

--向數(shù)據(jù)庫(kù)導(dǎo)入json相關(guān)jar包

loadjava -r -f -u scott/tiger@xxx.xxx.xxx.xxx:1521/orcl json.jar

--刪除指定jar

#dropjava -u scott/tiger@xxx.xxx.xxx.xxx:1521/orcl json.jar

在此,我們執(zhí)行導(dǎo)入,如下:

細(xì)節(jié):如果導(dǎo)入的jar包存在外部依賴,會(huì)報(bào)如下異常,繼續(xù)導(dǎo)入外部依賴只會(huì)使要導(dǎo)入的jar包越來(lái)越多,最終還不一定可以導(dǎo)入成功,得不償失,如下:

3、導(dǎo)入json.jar成功后再次查看當(dāng)前已導(dǎo)入的類文件如下

4、在數(shù)據(jù)庫(kù)SQL窗口執(zhí)行以下腳本,創(chuàng)建java源碼對(duì)象

create or replace and compile java source named "JsonUtil" as

import org.json.JSONArray;

import org.json.JSONException;

import org.json.JSONObject;

import java.lang.Integer;

public class JsonUtil {

//取json串單個(gè)節(jié)點(diǎn)值

public static String getValue(String jsonStr,String nodeName){

String nodeValue="";

try {

if(jsonStr==null||!jsonStr.startsWith("{")||!jsonStr.endsWith("}")){

nodeValue="";

}else{

JSONObject obj =new JSONObject(jsonStr);

nodeValue = obj.getString(nodeName);

}

} catch (JSONException e) {

nodeValue="";

}

return nodeValue;

}

//取json數(shù)組長(zhǎng)度便于循環(huán)處理

public static Integer getArrayLength(String jsonArrayStr){

Integer length=0;

try {

if(jsonArrayStr==null||!jsonArrayStr.startsWith("[")||!jsonArrayStr.endsWith("]")){

length=0;

}else{

JSONArray jsonArr = new JSONArray(jsonArrayStr);

length=jsonArr.length();

}

} catch (JSONException e) {

length=0;

}

return length;

}

//取json數(shù)組第index個(gè)元素

public static String getArrayValue(String jsonStr,Integer index){

String nodeValue="";

try {

if(jsonStr==null||!jsonStr.startsWith("[")||!jsonStr.endsWith("]")){

nodeValue="";

}else{

JSONArray jsonArr = new JSONArray(jsonStr);

nodeValue=jsonArr.getString(index);

}

} catch (JSONException e) {

nodeValue="";

}

return nodeValue;

}

}

創(chuàng)建成功后再次查詢可以看到對(duì)應(yīng)的class文件:

5、利用步驟4創(chuàng)建的class創(chuàng)建function(或procedure),在此為了使其跟目前數(shù)據(jù)庫(kù)已存在的json處理方法區(qū)分開(kāi),我們創(chuàng)建一個(gè)package,如下:

create or replace package jsonpkg

as

function getval(jsonstr varchar2,nodename varchar2) return varchar2;

function getarrval(jsonArrayStr varchar2,seqNo number) return varchar2;

function getarrlen(jsonArrayStr varchar2) return number;

end jsonpkg;

/

create or replace package body jsonpkg

as

function getval(jsonstr varchar2,nodename varchar2) return varchar2

as language java name 'JsonUtil.getValue(java.lang.String,java.lang.String) return java.lang.String';

function getarrval(jsonArrayStr varchar2,seqNo number) return varchar2

as language java name 'JsonUtil.getArrayValue(java.lang.String, java.lang.Integer) return java.lang.String';

function getarrlen(jsonArrayStr varchar2) return number

as language java name 'JsonUtil.getArrayLength(java.lang.String) return java.lang.Integer';

end jsonpkg;

/

創(chuàng)建成功后可以查看包說(shuō)明和主體:

6、測(cè)試

①簡(jiǎn)單json測(cè)試

②解析復(fù)雜json

至此,我們就可以很輕松的就取到j(luò)son串中任意節(jié)點(diǎn)的值(如果節(jié)點(diǎn)值為數(shù)組則可以先計(jì)算數(shù)組長(zhǎng)度再進(jìn)行l(wèi)oop循環(huán)處理,或直接用getarrval方法取指定數(shù)組元素的值)。

方法2:安裝開(kāi)源組件PL/JSON

下載地址: https://github.com/pljson/pljson

優(yōu)點(diǎn):安裝方便,解析方法較專業(yè);缺點(diǎn):新增數(shù)據(jù)庫(kù)對(duì)象較多,短期學(xué)習(xí)成本較高。文檔很詳細(xì),在此不再贅述。如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)我們網(wǎng)站的支持!

本文標(biāo)題: Oracle解析復(fù)雜json的方法實(shí)例詳解

本文地址: http://www.cppcns.com/shujuku/oracle/189956.html

總結(jié)

以上是生活随笔為你收集整理的oracle大对象实例_Oracle解析复杂json的方法实例详解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。