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

TSQLStoredProc的使用問題

尚未結案
ivankuo
中階會員


發表:132
回覆:272
積分:95
註冊:2002-11-21

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-10-14 15:19:28 IP:61.221.xxx.xxx 未訂閱
小弟的環境是D7(DBExpress) SQL2000 原來在使用TADOStoredProc可以用 ADOStoredProc1.ProcedureName:='spname'; ADOStoredProc1.Parameters.Refresh; i:=ADOStoredProc1.Parameters.Conut; 但在使用TSQLStoredProc元件發現沒有Parameters.Refresh;的方法, 也找不到替代的,請問要如何解決??
------
ivankuo
Mickey
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-10-14 23:29:50 IP:218.32.xxx.xxx 未訂閱
ivankuo 你好 :    我手邊機器沒有 MSSQL2000, 所以沒有辦法試...    用 SQLStoredProc1.Prepared := True;    試試看.    沒注意看題目, 你是要改用
ivankuo
中階會員


發表:132
回覆:272
積分:95
註冊:2002-11-21

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-10-15 09:31:19 IP:61.221.xxx.xxx 未訂閱
Mickey 前輩 我試過 SQLStoredProc1.Prepared := True; 一樣沒辦法,我現在是用DBExpress的元件。 我去搜尋過其他網站,有提到 SchemaName要給予owner的名稱,但是我也試過了,還是不行。我的paramm是在run time時期才去讀取而不是在design time 時候手動去加的。
------
ivankuo
Mickey
版主


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-10-15 11:11:52 IP:218.163.xxx.xxx 未訂閱
節錄二段 Delphi Help , 恐怕必須自己加 Parameter Provide input parameter values for the stored procedure, if necessary. If the server does not provide information about all stored procedure parameters, you may need to provide additional input parameter information, such as parameter names and data types. Using parameters at runtime With some datasets, if the name of the stored procedure is not specified until runtime, no TParam objects are automatically created for parameters and they must be created programmatically. This can be done using the TParam.Create method or the TParams.AddParam method:
var      P1, P2: TParam;
begin
  ...
  with StoredProc1 do begin
    StoredProcName := 'GET_EMP_PROJ';
    Params.Clear;
    P1 := TParam.Create(Params, ptInput);
    P2 := TParam.Create(Params, ptOutput);
    try
      Params[0].Name := 'EMP_NO';
      Params[1].Name := 'PROJ_ID';
      ParamByname('EMP_NO').AsSmallInt := 52;
      ExecProc;
      Edit1.Text := ParamByname('PROJ_ID').AsString;
    finally
      P1.Free;
      P2.Free;        end;
  end;
  ...
end;
發表人 - Mickey 於 2003/10/15 11:22:13
ivankuo
中階會員


發表:132
回覆:272
積分:95
註冊:2002-11-21

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-10-15 11:28:13 IP:61.221.xxx.xxx 未訂閱
這樣的話很不方便,我的ProcedureName也是run time 時期給予的,若無法自動得到parameter的話,非常不方便,我看目前只好先維持使用ADOStoredProc來搭配使用。
------
ivankuo
系統時間:2024-07-07 10:38:06
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!