請問有沒有人會用ADOStoredPorc呢? |
尚未結案
|
JS
一般會員 發表:22 回覆:26 積分:9 註冊:2002-07-20 發送簡訊給我 |
請問一下我這樣寫會error不知是何原因 ADOStoredProc1.ProcedureName:='dept_package.dept_sp'; ADOStoredProc1.Parameters.Clear;
ADOStoredProc1.Parameters.CreateParameter('dept_no',
ftInteger,
pdInput,
2,
11); ADOStoredProc1.Parameters.CreateParameter('io_cursor',
ftInterface,
pdInputOutput,
0,
null); ADOStoredProc1.Open; =====================================================================
Error Message:參數數目不正確
=====================================================================
Oracle package如下: CREATE OR REPLACE PACKAGE BODY dept_package AS PROCEDURE dept_sp(dept_no IN NUMBER,io_cursor IN OUT t_cursor) IS v_cursor t_cursor; BEGIN IF dept_no<>0 THEN
OPEN v_cursor FOR
SELECT * FROM DEPT WHERE DEPTNO=dept_no;
ELSE
OPEN v_cursor FOR
SELECT * FROM DEPT;
END IF; io_cursor:=v_cursor; END dept_sp;
END dept_package;
|
l630521
資深會員 發表:15 回覆:349 積分:372 註冊:2003-02-17 發送簡訊給我 |
|
JS
一般會員 發表:22 回覆:26 積分:9 註冊:2002-07-20 發送簡訊給我 |
|
change.jian
版主 發表:29 回覆:620 積分:439 註冊:2003-06-02 發送簡訊給我 |
|
l630521
資深會員 發表:15 回覆:349 積分:372 註冊:2003-02-17 發送簡訊給我 |
ADOStoredProc1.ProcedureName := 'Menu_Collect;1'; ADOStoredProc1.Parameters.CreateParameter('@RETURN_VALUE', ftInteger, pdReturnValue, 0, null); ADOStoredProc1.Parameters.CreateParameter('@Prg_ID', ftString, pdInput, 10, null); ADOStoredProc1.Parameters.ParamByName('@Prg_ID').Value := Trim(FSys_Name);這是小弟的用法,不過change.jian前輩的說法可能比較正確!畢竟小弟沒有用過Oracle。 Ian |
JS
一般會員 發表:22 回覆:26 積分:9 註冊:2002-07-20 發送簡訊給我 |
|
change.jian
版主 發表:29 回覆:620 積分:439 註冊:2003-06-02 發送簡訊給我 |
|
JS
一般會員 發表:22 回覆:26 積分:9 註冊:2002-07-20 發送簡訊給我 |
|
change.jian
版主 發表:29 回覆:620 積分:439 註冊:2003-06-02 發送簡訊給我 |
Hi,JS:
1.雖然我找不到相關的文件說明,但我認為應該是你把io_cursor的參數設為in out的關係,你要不要試試看直接改成out就好.(Delphi與Oracle都要改) 2.我看你Store procedure 裡有"o_cursor:=v_cursor;"這樣一行指令.老實說我很久沒碰oracle了,這樣的指令是否能正常work要請你再確認一下,一般應該是直接Open不是嗎?如下:
create or replace procedure REPORT_JOB_COST ( E_ID IN VARCHAR2, c1 out pg_ref_cursor.rpt_cursor ) is begin open c1 for SELECT EMPLOYEE_ID, EMPLOYEE_NAME, JOB_NAME, CALCULATE_JOB_COST(EMPLOYEE_JOBID) AS JOB_COST FROM EMPLOYEE, JOB WHERE EMPLOYEE_JOBID = E_ID; end; |
JS
一般會員 發表:22 回覆:26 積分:9 註冊:2002-07-20 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |