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

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

系統(tǒng) 2062 0

本系列文章導(dǎo)航

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

[Oracle]高效的PL/SQL程序設(shè)計(jì)(二)--標(biāo)量子查詢(xún)

[Oracle]高效的PL/SQL程序設(shè)計(jì)(三)--Package的優(yōu)點(diǎn)

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

[Oracle]高效的PL/SQL程序設(shè)計(jì)(五)--調(diào)用存儲(chǔ)過(guò)程返回結(jié)果集

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

在PL/SQL程序中, 我們會(huì)遇到需要先從一個(gè)結(jié)果集中取出若干記錄, 然后對(duì)每一條記錄進(jìn)行處理的情況, 最理想的做法是在一條SQL語(yǔ)句中完成, 但有時(shí)候因?yàn)樾枨蟮年P(guān)系所以不一定能實(shí)現(xiàn), 所以我們通常會(huì)定義幾個(gè)變量, 然后對(duì)結(jié)果集做循環(huán), 賦值給變量. 最典型的就是select XX into XX。我們也可以用定義一個(gè)記錄%rowtype的方法, 減少不必要的代碼量, 還能避免由于表中字段的變更造成的錯(cuò)誤。示例如下:

創(chuàng)建測(cè)試表:

create table t1 as select * from user_tables

創(chuàng)建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;

創(chuàng)建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;

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

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;

注:還有一個(gè)獲得列的數(shù)據(jù)類(lèi)型%TYPE

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

博文來(lái)源: http://blog.csdn.net/huanghui22/archive/2007/05/24/1624358.aspx

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


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产麻豆之光e奶女教师 | 看免费5xxaaa毛片30厘米 | 久久一区二区精品综合 | 99视频九九精品视频在线观看 | 一级毛片短视频 | 国产精品视频免费观看 | www.奇米第四色| 久久夜色精品 | 亚洲日本va| 国产欧美成人免费观看视频 | 婷婷在线网站 | 97se亚洲综合在线天天 | 国产色在线 | 亚洲 国产色在线视频 | 想看一级毛片 | 羞羞的视频网站 | 亚洲精品乱码久久久久久蜜桃欧美 | 四虎最新永久在线精品免费 | 久久成人永久免费播放 | 国产成人夜间影院在线观看 | 欧美99视频 | 99人中文字幕亚洲区 | 精品伊人久久大香线蕉网站 | 欧美一级高清片欧美国产欧美 | 99久久精品视香蕉蕉er热资源 | 久久一级黄色片 | 天天干天天操天天爱 | 国产高清福利91成人 | 色综合久久中文字幕综合网 | 久久爱.www| 私拍在线 | 久久久久久久影院 | 中文字幕在线视频精品 | 国产成人精品一区二区三在线观看 | 久一视频在线观看 | 欧美一区二区三区视频在线观看 | 亚洲综合色在线观看 | 日日射影院 | 日本免费一区二区久久人人澡 | a一级毛片免费高清在线 | 精品国产区一区二区三区在线观看 | www.欧美日本免费视频 |