Функция - это подпрограмма, которая вычисляет значение.
В этом учебном пособии вы узнаете, как создавать и удалять функции в Oracle/PLSQL с синтаксисом и примерами.
СОЗДАТЬ ФУНКЦИЮ (CREATE FUNCTION)
Как и на других языках программирования, вы можете создавать свои собственные функции в Oracle.
Синтаксис:
[ (параметр [, параметр, ...]) ]
RETURN тип_данных IS | AS
[локальные объявления]
BEGIN
исполняемые предложения
[EXCEPTION
обработчики исключений]
END [имя_функции];
При создании процедуры или функции, вы можете определить три типа параметров, которые могут быть объявлены:
IN - Параметр может ссылаться на процедуру или функцию. Значение параметра не может быть изменено процедурой или функцией.
OUT - параметр не может ссылаться на процедуру или функцию, но значение параметра может быть изменено процедурой или функцией.
IN OUT - Параметр может ссылаться на процедуру или функцию и значения параметра может быть изменено процедурой или функцией.
Пример
Рассмотрим на примере, как создать функцию в Oracle.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
CREATE OR REPLACE Function FindCourse ( name_in IN varchar2 ) RETURN number IS cnumber number; cursor c1 is SELECT course_number FROM courses_tbl WHERE course_name = name_in; BEGIN open c1; fetch c1 into cnumber; if c1%notfound then cnumber := 9999; end if; close c1; RETURN cnumber; EXCEPTION WHEN OTHERS THEN raise_application_error(-20001,'An error was encountered - '||SQLCODE||' -ERROR- '||SQLERRM); END; |
Эта функция называется FindCourse. Она имеет один параметр name_in и возвращает число. Функция возвращает course_number, если находит соответствие на основе course_name. В противном случае, она возвращает 99999.
Вы можете ссылаться на вашу новую функцию в запросе SQL следующим образом:
FROM courses
WHERE subject = 'Mathematics';
УДАЛИТЬ ФУНКЦИЮ (DROP FUNCTION)
После того, как вы создали функцию в Oracle, вам может понадобиться удалить ее из базы данных.
Синтаксис
Синтаксис удаления функция в Oracle:
имя_функции имя функции, которую вы хотите удалить.
Пример
Рассмотрим пример, как удалить функцию в Oracle.
В этом примере удаляем функцию под названием FindCourse.