欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

oracle 管道表函數2

系統 1923 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條評論
主站蜘蛛池模板: 91蜜芽尤物福利在线观看 | 男女性情视频 | 国产2区| 日韩欧美一区二区三区 | 一个看片免费视频www | 看一天影院 理论片 | 在线精品小视频 | 色综合五月色婷婷开心 | 不卡一区在线观看 | 国产精品久久久久久久久久 | 久久久国产精品x99av | 国产免费观看一区 | 亚洲欧美成人中文在线网站 | jizz丝袜老师 | 日韩欧美在线视频不卡免费视频 | 一区二区精品 | 精品伊人久久大线蕉地址 | 日本美女一区二区三区 | 欧美日韩在线视频播放 | 国产午夜精品在线 | 色悠久久久久综合网伊人男男 | 国产伦精品一区二区三区高清 | 五月天激激婷婷大综合蜜芽 | 九九热在线免费观看 | av免费在线观看国产 | 国产一区二区视频在线播放 | 久久精品久久精品国产大片 | 亚洲黄色一级大片 | 免费成人av | 日韩欧美第一页 | 日韩在线观看第一页 | 狠狠躁夜夜躁人人爽天天段 | 精品一区二区在线观看视频 | 亚洲v日韩v综合v精品v | 色综合久久精品中文字幕首页 | 深夜福利软件 | 中国在线播放精品区 | 国产成人精品在线观看 | 精品一区二区在线观看视频 | 99久久一区二区 | 亚洲午夜在线 |