Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.06.03;
Скачать: CL | DM;

Вниз

Как получить в Delphi выходной параметр из процедуры в пакете?   Найти похожие ветки 

 
DPashin   (2002-05-07 09:18) [0]

Я пробовал следующий код, но параметр возвращаться отказывается. Через TStoredProc процедуры в пакетах не видны,=> запустить нельзя. Что делать?

CREATE OR REPLACE
Package TESTPACK IS
PROCEDURE TestProc
( param1 IN OUT INTEGER);
END;
/

CREATE OR REPLACE
Package Body TESTPACK IS
PROCEDURE TestProc( param1 IN OUT INTEGER) is
begin
Param1:=1;
end;
END; -- Package Body TESTPACK
/

var Q:TQuery;
begin
Q:=TQuery.Create(nil);
try
Q.DataBaseName:="SALARY";
Q.SQL.Add("begin");
Q.SQL.Add("TestPack.TestProc(:Param1);");
Q.SQL.Add("end;");

Q.ParamByName("Param1").DataType:=ftInteger;
Q.ParamByName("Param1").ParamType:=ptInputOutput;
Q.ParamByName("Param1").asInteger:=0;
Q.ExecSQL;
ShowMessage(intToStr(Q.ParamByName("Param1").asInteger ));
finally
Q.Free;
end;
end;


 
ivv ©   (2002-05-07 09:35) [1]

в насройках bde configuration\drivers\native\oracle\
смени парамертр dll32 на SQLORA32, он корректно работает со StoredProc, а SQLORA8 - c blob


 
DPashin   (2002-05-13 09:39) [2]

Попробовал, не помогает.
При SQLORA32 на соединении с сервером выскакивает ошибка (Internal чего-то там). Есть подозрение, что SQLORA32 работает только с Oracle 7, т.к. на Oracle 7 все ок.

Мне нужно решить проблему для Oracle 8.1.6.


 
Sergey13 ©   (2002-05-13 09:56) [3]

C BDEшным доступом не пробовал. С DOA такое работает.
А тебе нужна именно процедура? Почему не хочешь переделать ее в функцию. Может проще будет. Отселектил из дуала и все.


 
Judith ©   (2002-05-13 15:31) [4]

Попробуй написать имя пакета и процедуры большими буквами. dll32 должно стоять SQLORA32.DLL


 
DPashin   (2002-05-14 09:37) [5]

>Sergey13
>C BDEшным доступом не пробовал. С DOA такое работает.
К сожалению, нужно под BDE.

>А тебе нужна именно процедура?
Да. Представить в виде функции и селектить из дуала не получиться, т.к. процедура модифицирует таблицы.
----------------
>Judith
>Попробуй написать имя пакета и процедуры большими буквами.
Пробовал. Не помогло.

>dll32 должно стоять SQLORA32.DLL
SQLORA32 не работает с Oracle 8.


 
Reindeer Moss Eater   (2002-05-14 09:59) [6]

SQLORA32.dll прекрасно работает с любой восьмеркой



Страницы: 1 вся ветка

Текущий архив: 2002.06.03;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.011 c
14-7190
Sniffer
2002-04-24 11:37
2002.06.03
Case-пакеты


8-7112
MC TOL
2002-01-03 10:24
2002.06.03
Вопросик по OpenGL


1-6980
Smok_er
2002-05-22 23:53
2002.06.03
Помогите найти самый быстрый способ


1-6989
John Kayfolom
2002-05-22 16:31
2002.06.03
Запуск DOS программы и получение ErrorLevel


7-7249
Серый
2002-03-03 19:09
2002.06.03
GM56E-V и Win XP