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

[Oracle]高效的PL/SQL程序設計(六)--%ROWTYPE的

系統 1893 0

本系列文章導航

[Oracle]高效的PL/SQL程序設計(一)--偽列ROWNUM使用技巧

[Oracle]高效的PL/SQL程序設計(二)--標量子查詢

[Oracle]高效的PL/SQL程序設計(三)--Package的優點

[Oracle]高效的PL/SQL程序設計(四)--批量處理

[Oracle]高效的PL/SQL程序設計(五)--調用存儲過程返回結果集

[Oracle]高效的PL/SQL程序設計(六)--%ROWTYPE的使用

在PL/SQL程序中, 我們會遇到需要先從一個結果集中取出若干記錄, 然后對每一條記錄進行處理的情況, 最理想的做法是在一條SQL語句中完成, 但有時候因為需求的關系所以不一定能實現, 所以我們通常會定義幾個變量, 然后對結果集做循環, 賦值給變量. 最典型的就是select XX into XX。我們也可以用定義一個記錄%rowtype的方法, 減少不必要的代碼量, 還能避免由于表中字段的變更造成的錯誤。示例如下:

創建測試表:

create table t1 as select * from user_tables

創建PACKAGE HEAD:

create or replace packageType_demo is

procedure process1(p_record in t1 % rowtype);
procedure process_data(p_inputs in varchar2 );

end Type_demo;

創建PACKAGE BODY:

create or replace packagebodyType_demo is

procedure process1(p_record in t1 % rowtype)
as
begin
dbms_output.put_line(p_record.tablespace_name);
end ;

procedure process_data(p_inputs in varchar2 )
as
begin
for x in ( select * from t1 where table_name like p_inputs)
loop
process1(x);
end loop;
end ;

end Type_demo;

上面的例子得到的是整個表的記錄類型, 如果想要得到某幾個列的記錄類型, 可以按照如下做法:

create or replace packageType_demo is

cursor template_cursor
is select table_name,tablespace_name from t1;

-- typercisrefcursor;

procedure process2(p_record in template_cursor % rowtype);
procedure process_data(p_cname in varchar2 ,p_inputs in varchar2 );
end Type_demo;
create or replace packagebodyType_demo is

procedure process2(p_record in template_cursor % rowtype)
as
begin
dbms_output.put_line(p_record.tablespace_name);
end ;

procedure process_data(p_cname in varchar2 ,p_inputs in varchar2 )
as
-- l_cursorrc;
l_cursorsys_refcursor;
l_rectemplate_cursor
% rowtype;
begin
open l_cursor
for
' selecttable_name,tablespace_namefromt1where ' || p_cname || ' like:x ' usingp_inputs;
loop
fetch l_cursor into l_rec;
exit when l_cursor % notfound;
process2(l_rec);
end loop;
end ;

end Type_demo;

注:還有一個獲得列的數據類型%TYPE

l_tablenamet1.tablename % type;
select XX into l_tablename from t1 where...

博文來源: http://blog.csdn.net/huanghui22/archive/2007/05/24/1624358.aspx

[Oracle]高效的PL/SQL程序設計(六)--%ROWTYPE的使用


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 人人香蕉 | 国产成人精品一区二区三区电影 | 天天做天天爱天天综合网 | a久久久久一级毛片护士免费 | 精品日韩欧美一区二区三区在线播放 | 日韩一二三区视频 | 日本免费a视频 | 亚洲一区国产二区 | 久久欧美精品1024你懂得 | 一区视频 | 美女一级 | 91网址在线 | 中文线码中文高清播放中 | 亚洲第一女人av | 三级网站在线看 | 国产精品黄大片观看 | 精东视频污 | 午夜欧美性欧美 | 一本到在线观看视频不卡 | 国产精品久久嫩一区二区免费 | 欧美激情精品久久久久久久 | 日本人视频jizz69页码 | 欧美一区二区三区在线看 | 日本高清午夜色wwwσ | 日本在线播放不卡一区二区三区 | 成人在线观看国产 | 啪啪免费网站入口链接 | 国产成人18黄网站免费 | 国产在线精品成人一区二区三区 | 星际迷航4| 一级做一级爱a做片性视频视频 | 草草国产成人免费视频 | 91社区影院 | 27xxoo无遮挡动态视频 | 亚洲高清视频一区 | 国产精选经典三级小泽玛利亚 | 草草视频免费在线观看 | 青青草国产成人久久91网 | 91久久久久久久久久久久久久 | 午夜国产亚洲精品一区 | 大片在线免费观看 |