亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

Oracle中通過存儲過程中返回數據集及在Delphi中使用

2019-11-18 18:01:10
字體:
來源:轉載
供稿:網友
 

一、使用存儲過程返回數據集
Oracle中存儲過程返回數據集是通過ref cursor類型數據的參數返回的,而返回數據的參數應該是out或in out類型的。
由于在定義存儲過程時無法直接指定參數的數據類型為:ref cursor,而是首先通過以下方法將ref cursor進行了重定義:
create or replace package FuxjPackage is
type FuxjResultSet is ref cursor;
--還可以定義其他內容
end FuxjPackage;
再定義存儲過程:
create or replace PRocedure UpdatefuxjExample (sDM in char,sMC in char, pRecCur in out FuxjPackage.FuxjResultSet)
as
begin
update fuxjExample set mc=sMC where dm=sDM;

if SQL%ROWCOUNT=0 then
rollback;
open pRecCur for
select '0' res from dual;
else
commit;
open pRecCur for
select '1' res from dual;
end if;
end;

create or replace procedure InsertfuxjExample (sDM in char,sMC in char, pRecCur in out FuxjPackage.FuxjResultSet)
as
begin
insert into FuxjExample (dm,mc) values (sDM,sMC);
commit;
open pRecCur for
select * from FuxjExample;
end;

二、在Delphi中調用返回數據集的存儲過程
可以通過TstoredProc或TQuery控件來調用執行返回數據集的存儲,數據集通過TstoredProc或TQuery控件的參數返回,注意參數的DataType類型為ftCursor,而參數的ParamType類型為ptInputOutput。
使用TstoredProc執行UpdatefuxjExample的相關設置為:
object StoredProc1: TStoredProc
DatabaseName = 'UseProc'
StoredProcName = 'UPDATEFUXJEXAMPLE'
ParamData = <
item
DataType = ftString
Name = 'sDM'
ParamType = ptInput
end
item
DataType = ftString
Name = 'sMC'
ParamType = ptInput
end
item
DataType = ftCursor
Name = 'pRecCur'
ParamType = ptInputOutput
Value = Null
end>
end
執行方法為:
StoredProc1.Params.Items[0].AsString:=Edit1.Text; //給參數賦值;
StoredProc1.Params.Items[1].AsString:=Edit2.Text; //給參數賦值;
StoredProc1.Active:=False;
StoredProc1.Active:=True; //返回結果集
使用TQuery執行InsertfuxjExample的相關設置為:
object Query1: TQuery
DatabaseName = 'UseProc'
SQL.Strings = (
'begin'
' InsertfuxjExample(sDM=>大笑M,sMC=>:mc,pRecCur=>:RecCur);'
'end;')
ParamData = <
item
DataType = ftString
Name = 'DM'
ParamType = ptInput
end
item
DataType = ftString
Name = 'mc'
ParamType = ptInput
end
item
DataType = ftCursor
Name = 'RecCur'
ParamType = ptInputOutput
end>
end
執行方法為:
Query1.Params.Items[0].AsString:=Edit3.Text; //給參數賦值;
Query1.Params.Items[1].AsString:=Edit4.Text; //給參數賦值;
Query1.Active:=False;
Query1.Active:=True;


if SQL%ROWCOUNT=0 then
rollback;
open pRecCur for
select '0' res from dual;
else
commit;
open pRecCur for
select '1' res from dual;
end if;
end;

create or replace procedure InsertfuxjExample (sDM in char,sMC in char, pRecCur in out FuxjPackage.FuxjResultSet)
as
begin
insert into FuxjExample (dm,mc) values (sDM,sMC);
commit;
open pRecCur for
select * from FuxjExample;
end;

二、在Delphi中調用返回數據集的存儲過程
可以通過TstoredProc或TQuery控件來調用執行返回數據集的存儲,數據集通過TstoredProc或TQuery控件的參數返回,注意參數的DataType類型為ftCursor,而參數的ParamType類型為ptInputOutput。
使用TstoredProc執行UpdatefuxjExample的相關設置為:
object StoredProc1: TStoredProc
DatabaseName = 'UseProc'
StoredProcName = 'UPDATEFUXJEXAMPLE'
ParamData = <
item
DataType = ftString
Name = 'sDM'
ParamType = ptInput
end
item
DataType = ftString
Name = 'sMC'
ParamType = ptInput
end
item
DataType = ftCursor
Name = 'pRecCur'
ParamType = ptInputOutput
Value = Null
end>
end
執行方法為:
StoredProc1.Params.Items[0].AsString:=Edit1.Text; //給參數賦值;
StoredProc1.Params.Items[1].AsString:=Edit2.Text; //給參數賦值;
StoredProc1.Active:=False;
StoredProc1.Active:=True; //返回結果集
使用TQuery執行InsertfuxjExample的相關設置為:
object Query1: TQuery
DatabaseName = 'UseProc'
SQL.Strings = (
'begin'
' InsertfuxjExample(sDM=>大笑M,sMC=>:mc,pRecCur=>:RecCur);'
'end;')
ParamData = <
item
DataType = ftString
Name = 'DM'
ParamType = ptInput
end
item
DataType = ftString
Name = 'mc'
ParamType = ptInput
end
item
DataType = ftCursor
Name = 'RecCur'
ParamType = ptInputOutput
end>
end
執行方法為:
Query1.Params.Items[0].AsString:=Edit3.Text; //給參數賦值;
Query1.Params.Items[1].AsString:=Edit4.Text; //給參數賦值;
Query1.Active:=False;
Query1.Active:=True;

附:創建返回數據集的存儲過程 簡單框架

1.
create or replace package TestPackage is
type TestResultSet is ref cursor;
end TestPackage ;

2.
create or replace procedure Test
(
pRecCur in out TestPackage .TestResultSet
)
as
begin
open pRecCur for
select * from table;
end;



上一篇:在Delphi中通過函數獲取GUID

下一篇:模擬delphi編輯窗體操作控件。。。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲日韩中文字幕在线播放| 欧洲日本亚洲国产区| 51色欧美片视频在线观看| 欧美在线视频播放| 亚洲日本欧美日韩高观看| 欧美精品videos另类日本| 日韩成人中文字幕在线观看| 国产精品视频区| 欧美视频在线视频| 国内精品久久久久久影视8| 精品久久久久久久久久国产| 国产v综合v亚洲欧美久久| 欧美日韩爱爱视频| 精品无人区太爽高潮在线播放| 久久人人爽亚洲精品天堂| 欧美成人免费在线观看| 亚洲欧美中文另类| 亚洲第一视频在线观看| 亚洲精品一区久久久久久| 欧美另类极品videosbestfree| 精品国产一区二区在线| 欧美午夜精品在线| 日韩小视频网址| 这里只有精品在线观看| 在线激情影院一区| 午夜精品国产精品大乳美女| 中文字幕无线精品亚洲乱码一区| 成人a免费视频| 亚洲欧美日韩直播| 成人激情视频在线播放| 狠狠久久五月精品中文字幕| 国产suv精品一区二区三区88区| 欧美精品免费看| 高跟丝袜欧美一区| 欧美福利视频网站| 亚洲国产又黄又爽女人高潮的| 91久久国产婷婷一区二区| 久久久av网站| 欧美日韩国产91| 日韩精品免费综合视频在线播放| 久久伊人免费视频| 久青草国产97香蕉在线视频| 国产va免费精品高清在线| 国产精品日韩欧美综合| 欧美日韩性生活视频| 国产精品久久久久久亚洲影视| 国产精品综合久久久| 国产欧美日韩最新| 亚洲国产精品资源| 亚洲一区二区三区视频播放| 成人羞羞国产免费| 亚洲午夜精品久久久久久性色| 午夜精品蜜臀一区二区三区免费| 欧美日韩日本国产| 国产精品爽黄69| 北条麻妃在线一区二区| 国产在线视频2019最新视频| 亚洲大胆人体av| 欧美疯狂xxxx大交乱88av| 97av在线视频| 欧美日本高清一区| 在线观看国产成人av片| 97热精品视频官网| 成人在线国产精品| 国内精品久久久久久久久| 国产性猛交xxxx免费看久久| 91久久精品一区| 国产欧美一区二区三区久久人妖| 精品国产91久久久久久| 日韩精品一区二区三区第95| 伊人久久免费视频| 亚洲福利影片在线| 久久全国免费视频| 久久频这里精品99香蕉| 色婷婷av一区二区三区久久| 欧美丝袜一区二区三区| 成人免费视频在线观看超级碰| 国产精品色悠悠| 欧美亚洲国产成人精品| 色偷偷888欧美精品久久久| 日韩av电影手机在线| 国产精品日韩欧美大师| 97视频在线观看成人| 性色av一区二区三区免费| 欧美高清在线观看| 欧美日韩国产中字| 一本色道久久综合亚洲精品小说| 亚洲第一黄色网| 国产精品成人aaaaa网站| 国产欧美一区二区三区视频| 亚洲精品免费在线视频| 亚洲精品suv精品一区二区| 精品国产乱码久久久久久虫虫漫画| 国产精品久久久久国产a级| 亚洲国产天堂久久综合| 亚洲欧美综合图区| 欧美在线视频在线播放完整版免费观看| 亚洲精品第一国产综合精品| 亚洲第一网站免费视频| 在线中文字幕日韩| 亚洲免费视频一区二区| 国产一区二区免费| 成人激情视频小说免费下载| 55夜色66夜色国产精品视频| 性欧美亚洲xxxx乳在线观看| 91亚洲va在线va天堂va国| 岛国av在线不卡| 中文字幕久热精品视频在线| 成人av电影天堂| 亚洲国产天堂久久综合| 亚洲人成绝费网站色www| 亚洲 日韩 国产第一| 成人激情在线播放| 久久久久亚洲精品成人网小说| 97视频在线观看免费高清完整版在线观看| 久久91精品国产91久久久| 欧美成人自拍视频| 欧美午夜丰满在线18影院| 亚洲欧美日韩精品久久| 全色精品综合影院| 中文字幕视频在线免费欧美日韩综合在线看| 久久成人精品电影| 国内精品久久久久影院优| 久久av资源网站| 九九热最新视频//这里只有精品| 国产精品久久久久久久久久久久久| 91啪国产在线| 日韩欧美在线免费观看| 日韩在线中文字幕| 亚洲精品mp4| 亚洲女成人图区| 国产成人综合精品在线| 欧美日韩国产影院| 国模精品一区二区三区色天香| 国产精品一区专区欧美日韩| 亚洲热线99精品视频| 欧美又大粗又爽又黄大片视频| 欧美大片网站在线观看| 欧美日韩国产色视频| 久久的精品视频| 成人有码视频在线播放| 97欧美精品一区二区三区| 欧美视频精品一区| 亚洲一区二区三区成人在线视频精品| 91精品视频大全| 欧美性xxxx极品hd满灌| 亚洲性日韩精品一区二区| 日韩欧美999| 91精品国产九九九久久久亚洲| 久久久久久久91| 亚洲国产一区二区三区在线观看| 精品日韩美女的视频高清| 成人午夜在线观看| 欧洲s码亚洲m码精品一区| 九九精品视频在线观看| 欧美剧在线观看| 日韩美女激情视频| 欧美日韩另类视频| 精品精品国产国产自在线| 国产亚洲欧美另类中文| 在线亚洲国产精品网| 亚洲最大av在线| 国产精品美女免费视频| 欧美日韩成人在线视频|