Delphi 3 и создание приложений баз данных

       

Создание хранимой процедуры


Хранимая процедура создается оператором

CREATE PROCEDURE ИмяПроцедуры

[ (входной_параметр тип_данньк [, входной_параметр тип_данных...])]

[RETURNS

(выходной_параметр тип_данньк [, выходной_параметр тип_данньк ...])] AS

<тело процедуры>;

Входные параметры

служат для передачи в процедуру значений из вызывающего приложения. Изменять значения входных параметров в теле процедуры бессмысленно: эти изменения будут забыты после окончания работы процедуры.

Выходные параметры

служат для возврата результирующих значений. Значения выходных параметров устанавливаются в теле процедуры и после окончания ее работы передаются в вызывающее приложение.

И входные, и выходные параметры могут быть опущены, если в них нет необходимости.

Тело процедуры имеет формат

[<объявление локальных переменных процедуры>]

BEGIN

< оператор>

[<оператор> ...]

END

Пример.

Хранимая процедура FIND_MAX_KOLVO возвращает в выходном параметре MAX_KOLVO максимальное количество отгруженного со склада товара, наименование которого передается во входном параметре IN_TOVAR:

CREATE PROCEDURE FIND_MAX_KOLVO (IN_TOVAR VARCHAR(20))

RETURNS(MAX_KOLVO INTEGER) AS

BEGIN

SELECT MAX(KOLVO) FROM RASHOD WHERE TOVAR = : IN_TOVAR

INTO : MAX_KOLVO;

SUSPEND;

END

Заметим, что в приведенной процедуре за ненадобностью отсутствует определение локальных переменных.



Содержание раздела