全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1733
推到 Plurk!
推到 Facebook!

使用Stored Procedure連結DataSource元件的用法

尚未結案
ankin
一般會員


發表:12
回覆:7
積分:3
註冊:2002-10-17

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-05-23 17:47:06 IP:211.74.xxx.xxx 未訂閱
我寫了一個storedprocedure去select某個table的所有資料,然後使用TStoredProc元件指向它,再用一個datasource元件指向TStoredProc元件,dbgrid指向datasource但卻不行??? Stored Procedure的code如下: create or replace procedure ankin(temp out ankin_cur%rowtype) as cursor ankin_cur is select em_empname From treemp; begin open cursor; end ankin; 在一個Button的click event寫如下: StoredProc1.prepare; StoredProc1.open; 其實我的用意是即然TStoredProc是個TDataSet元件,那代表是不是可以比照Table元件的用法。 請回答此篇的先進能否舉個自己用過的範例,謝謝!
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-05-26 10:55:42 IP:218.163.xxx.xxx 未訂閱
Using Oracle Reference Cursor Type ,PL/SQL as following:
-- Type declaration
create or replace package mickpkg as
  type cur is ref cursor;
end;
/    -- Using Function
create or replace function FOpenQry(S varchar2) return mickpkg.cur as
cc mickpkg.cur;
begin
   open cc for S;
   return cc;
end;
/    -- Using Procedure
create or replace procedure POpenQry(S in varchar2,cc out mickpkg.cur) as
begin
   open cc for S;
end;
/

Delphi Sample Code :
-- using function
  with StoredProc1 do begin
    StoredProcName := 'FOPENQRY';
    Params.ParamByName('Result').DataType := ftCursor;
    Params.ParamByName('S').AsString := 'select * from test';
    Prepare;
    Open;
  end;    -- using procedure :
  with StoredProc2 do begin
    StoredProcName := 'POPENQRY';
    Params.ParamByName('cc').DataType := ftCursor;
    Params.ParamByName('S').AsString := 'select * from test';
    Prepare;
    Open;
  end;    
系統時間:2024-06-02 1:05:08
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!