黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

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

系統 2202 0

本系列文章導航

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

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

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

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

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

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

Oracle支持通過ref游標在調用存儲過程后返回結果集,使用游標在內存消耗以及時間上都要大大的優于返回數組變量的做法!

示例如下:數據庫方面,建立一個Package

create or replace packageref_cur_demo is
typerc
is ref cursor ;
procedure ref_cursor(p_owner in varchar2 ,p_cursor in outrc);
end ref_cur_demo;

create or replace packagebodyref_cur_demo is

procedure ref_cursor(p_owner in varchar2 ,p_cursor in outrc)
is
begin
open p_cursor for select object_name ,object_type from all_objects where owner = p_owner and rownum < 3 ;
end ;

end ref_cur_demo;

程序方面使用C#建立一個小型應用程序,主要代碼如下:

Oracle.DataAccess.Client.OracleConnectionoracleConnection1 = new OracleConnection( " datasource=precolm2;userid=colmtest;password=colmtest " );
oracleConnection1.Open();
string strSQL = @" ref_cur_demo.ref_cursor " ;

Oracle.DataAccess.Client.OracleDataAdapterda
= new Oracle.DataAccess.Client.OracleDataAdapter();
Oracle.DataAccess.Client.OracleCommandcmd
= new Oracle.DataAccess.Client.OracleCommand(strSQL,oracleConnection1);
cmd.CommandType
= CommandType.StoredProcedure;

Oracle.DataAccess.Client.OracleParameterpram
= new Oracle.DataAccess.Client.OracleParameter( " p_owner " ,Oracle.DataAccess.Client.OracleDbType.Varchar2);
pram.Value
= " COLMTEST " ;
cmd.Parameters.Add(pram);

Oracle.DataAccess.Client.OracleParameterpram1
= new Oracle.DataAccess.Client.OracleParameter( " p_cursor " ,Oracle.DataAccess.Client.OracleDbType.RefCursor);
pram1.Direction
= ParameterDirection.Output;
cmd.Parameters.Add(pram1);

da.SelectCommand
= cmd;

DataSetds
= new DataSet();

da.Fill(ds);

this .dataGrid1.DataSource = ds.Tables[ 0 ].DefaultView;

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

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


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論