亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

oracle 管道表函數2

系統 2070 0

??? ??

?

?由于上一篇關于管道表函數寫的有些粗糙,追加一篇,方便大家理解。兩個函數完成管道表函數數據的初始化,所以設計到一個函數中調用另一個函數獲取含數據部分。

????? 一下是完整代碼:

?????

???? 1:創建 row類型

?

?????create or replace type subwhiteblack_row_type as object
???????(
??????? spid number,
??????? spname varchar(200),
??????? whitegroupcount number,
??????? whitelistcount number,
??????? whiteaddedcount number,
??????? whitenoaddedcount number,
??????? whitedemandcount number,
??????? blackcoumt number
???????)

???

??? 2:創建table類型

????

???????create or replace type subwhiteblack_table_type as table of subwhiteblack_row_type

?

????3:創建獲取row數據的function

????

????CREATE OR REPLACE FUNCTION GETSUBWHITEBLACKBYID
????(
????? SPID IN NUMBER ,
????? SPNAME IN VARCHAR
????)
????RETURN? SUBWHITEBLACK_ROW_TYPE
????AS
???? WHITELISTTOTALCOUNT NUMBER;
???? WHITEGROUPCOUNT NUMBER;
???? WHITEADDEDCOUNT NUMBER;
???? WHITENOADDEDCOUNT NUMBER;
???? WHITEDEMANDCOUNT NUMBER;
???? BLACKCOUNT NUMBER;
???? RESULTCOUNT NUMBER;
???? ISTABLEEXIST NUMBER ;
???? BASESTRSQL VARCHAR(2000);
???? STRSQL VARCHAR(2000);
???? CONSTANTSTR VARCHAR(20) ;
???? V_SUBWHITEBLACK_ROW SUBWHITEBLACK_ROW_TYPE ;
????BEGIN
????? --自定義變量初始化
????? WHITELISTTOTALCOUNT := 0;
????? WHITEGROUPCOUNT := 0;
????? WHITEADDEDCOUNT := 0;
????? WHITENOADDEDCOUNT := 0;
????? WHITEDEMANDCOUNT := 0;
????? BLACKCOUNT := 0;
????? RESULTCOUNT := 0;
????? ISTABLEEXIST := 0;
?????
????? --查詢企業白名單組總數的SQL
????? STRSQL := 'SELECT COUNT(WHITELIST.ID) FROM NM_WHITE_LIST WHITELIST WHERE 1=1 ';
????? IF SPID > 0 THEN
????????? STRSQL := STRSQL || 'AND WHITELIST.SP_ID ='||SPID;
????? END IF ;
????? IF SPID <= 0 THEN
????????? RETURN V_SUBWHITEBLACK_ROW ;
????? END IF ;
????? --獲得企業白名單組數,如果大于0 執行分組查詢
????? EXECUTE IMMEDIATE? STRSQL INTO? RESULTCOUNT ;
????? IF RESULTCOUNT > 0 THEN
???????? STRSQL := STRSQL || ' GROUP BY WHITELIST.SP_ID ' ;
???????? ---獲取該企業的白名單組總數
???????? EXECUTE IMMEDIATE? STRSQL INTO? WHITEGROUPCOUNT ;
????? END IF ;
????? STRSQL := 'SELECT COUNT(*) FROM ALL_TABLES TALBES WHERE TALBES.TABLE_NAME = ''NM_NET_USER_'||SPID||'''' ;
????? EXECUTE IMMEDIATE STRSQL INTO ISTABLEEXIST ;
????? IF ISTABLEEXIST > 0 THEN
??????? BASESTRSQL := 'SELECT COUNT(U.MDN) FROM NM_NET_USER_'||SPID||' U ' ;
??????? ---企業已填加白名單數????
??????? STRSQL := BASESTRSQL || ' WHERE U.STATUS IN (1,2)' ;
??????? EXECUTE IMMEDIATE? STRSQL INTO? WHITEADDEDCOUNT ;
??????? ---企業點播白名單數
??????? STRSQL := BASESTRSQL || ' WHERE U.STATUS = 3' ;
??????? EXECUTE IMMEDIATE? STRSQL INTO? WHITEDEMANDCOUNT ;
??????? ---企業未添加白名單數
??????? STRSQL := BASESTRSQL || ' WHERE U.STATUS = 4' ;
??????? EXECUTE IMMEDIATE? STRSQL INTO? WHITENOADDEDCOUNT ;
??????? ---企業白名單總數
??????? WHITELISTTOTALCOUNT := WHITEADDEDCOUNT + WHITEDEMANDCOUNT + WHITENOADDEDCOUNT ;
????? END IF ;
????? ---獲取企業黑名單總數SQL
????? STRSQL := 'SELECT COUNT(BLACK.ID) FROM NM_BLACK_AND_OBJECT BLACK WHERE BLACK.SP_ID ='||SPID ;
????? --如果大于0 執行分組查詢
????? EXECUTE IMMEDIATE? STRSQL INTO? RESULTCOUNT ;
????? IF RESULTCOUNT > 0 THEN
???????? STRSQL := STRSQL ||' GROUP BY BLACK.SP_ID'? ;
???????? ---獲取該企業的黑名單總數
???????? EXECUTE IMMEDIATE STRSQL INTO BLACKCOUNT ;
????? END IF ;
????? V_SUBWHITEBLACK_ROW :=SUBWHITEBLACK_ROW_TYPE(SPID ,SPNAME,WHITEGROUPCOUNT,WHITELISTTOTALCOUNT,WHITEADDEDCOUNT,WHITENOADDEDCOUNT,WHITEDEMANDCOUNT,BLACKCOUNT);
?????
????? RETURN V_SUBWHITEBLACK_ROW ;
????END ;

?

??? 4:創建獲取table數據function

?

????? ?????CREATE OR REPLACE FUNCTION GETSUBWHITEBLACKLIST
?????(
????? MAINACCOUNTID IN NUMBER,
????? SUBACCOUNTNAME IN VARCHAR
?????)
?????RETURN SUBWHITEBLACK_TABLE_TYPE PIPELINED
?????AS
?????V_ROW_TYPE SUBWHITEBLACK_ROW_TYPE;
????? SPID NUMBER;
????? SPNAME VARCHAR(200);
????? WHITEGROUPCOUNT NUMBER;
????? WHITELISTCOUNT NUMBER;
????? WHITEADDEDCOUNT NUMBER;
????? WHITENOADDEDCOUNT NUMBER;
????? WHITEDEMANDCOUNT NUMBER;
????? BLACKCOUMT NUMBER;
????? RESULTCOUNT NUMBER;
????? ISTABLEEXIST NUMBER ;
????? STRSQL VARCHAR(2000);
????? CONSTANTSTR VARCHAR(20) ;
????? TYPE T_CUR IS REF CURSOR;
????? V_PCUR T_CUR;
????? TYPE NM_SP_INFO_AAT IS TABLE OF NM_SP_INFO.ID%TYPE
????? INDEX BY PLS_INTEGER;
????? NM_SP_INFO_IDS NM_SP_INFO_AAT ;
????? TYPE NM_SP_INFO_BBT IS TABLE OF NM_SP_INFO.SP_NAME%TYPE
????? INDEX BY PLS_INTEGER;
????? NM_SP_INFO_NAMES NM_SP_INFO_BBT ;
?????BEGIN

?????? ---初始化主賬戶名稱
?????? CONSTANTSTR := '主賬戶' ;
?????? IF? MAINACCOUNTID > 0 THEN
????????? IF SUBACCOUNTNAME IS NOT NULL AND INSTR(CONSTANTSTR,SUBACCOUNTNAME,-1,1) > 0 THEN
???????????? V_ROW_TYPE := GETSUBWHITEBLACKBYID(MAINACCOUNTID,CONSTANTSTR);??????? PIPE ROW (V_ROW_TYPE);
????????? END IF ;
????????? IF SUBACCOUNTNAME IS? NULL THEN
???????????? V_ROW_TYPE := GETSUBWHITEBLACKBYID(MAINACCOUNTID,CONSTANTSTR);
???????????? PIPE ROW (V_ROW_TYPE);
????????? END IF ;
?????? END IF ;

?????? STRSQL := 'SELECT SP.ID SPID ,SP.SP_NAME NAME FROM NM_SP_INFO SP WHERE SP.ID <> 0 AND SP.OPEN_SUBACCOUNT = 1' ;
?????? STRSQL := STRSQL || ' AND SP.ID <>'||MAINACCOUNTID||' AND SP.SP_GRPID ='||MAINACCOUNTID ;
?????? IF? SUBACCOUNTNAME IS NOT NULL THEN
?????????? STRSQL := STRSQL || ' AND SP.SP_NAME LIKE (''%'||SUBACCOUNTNAME||'%'')' ;
?????? END IF ;
?????? EXECUTE IMMEDIATE 'SELECT COUNT(*) FROM ('||STRSQL||')' INTO RESULTCOUNT ;
?????????? --如果沒有子賬戶信息,則退出;否則繼續執行
?????? IF RESULTCOUNT = 0 THEN
????????? RETURN ;
?????? END IF ;
?????? IF RESULTCOUNT > 0 THEN
????????? OPEN V_PCUR FOR STRSQL;
????????? FETCH V_PCUR BULK COLLECT INTO NM_SP_INFO_IDS,NM_SP_INFO_NAMES;
????????? FOR I IN NM_SP_INFO_IDS.FIRST .. NM_SP_INFO_IDS.LAST
????????? LOOP

???????????? --此處調用獲取行數據的function 進行標量賦值
????????????? V_ROW_TYPE := GETSUBWHITEBLACKBYID(NM_SP_INFO_IDS(I),NM_SP_INFO_NAMES(I));
????????????? PIPE ROW (V_ROW_TYPE);
????????? END LOOP ;
????????? CLOSE V_PCUR ;
?????? END IF ;

?????END ;

?

?

? 5:java中調用方法

???? //? 為參數站位符 , 和普通select語句沒什么太大區別

???? select * from table(getSubWhiteBlackList(?,?)) ;

?

?

? <a ></a>

?

???

?

?


?

?

??

oracle 管道表函數2


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久久久九九精品影院 | 日本在线高清不卡 | 99精品国产三级在线观看 | 91青青青国产在观免费影视 | 在线视频不卡国产在线视频不卡 | 久久99精品一区二区三区 | 亚洲国产香蕉视频欧美 | 国产精品久久在线观看 | 四虎精品成人免费影视 | 在线观看视频一区 | 91成人免费福利网站在线 | 国产一区二区三区视频 | 人人插97 | 视频一区国产精戏刘婷 | 日韩三级一区二区 | 亚洲国产综合人成综合网站00 | 最新香蕉97超级碰碰碰碰碰久 | 色国产在线 | 亚洲精品乱码久久久久 | 亚洲精品高清国产一线久久97 | 久草热视频 | 国产一级特黄高清免费大片 | 青青青免费手机版视频在线观看 | 亚洲精品国产suv一区88 | 久久国产视频网 | 狠狠激情 | 欧美wwwwww| 亚洲国产成人久久77 | 黄色毛片视频网站 | 在线观看国产一区亚洲bd | 久色精品 | 日本免费小视频 | 久久青草精品一区二区三区 | 香蕉久久一区二区三区 | 色香欲综合成人免费视频 | 五月婷婷激情 | 日韩精品一区二区三区毛片 | 国产精品欧美日韩视频一区 | 九九久久亚洲综合久久久 | 伊人久久在线视频 | 九九九九九九伊人 |