pk_clients (пакет для работы с клиентскими данными);
pk_stocks (пакет для работы со складами);
pk_orders (пакет для обработки заказов);
…
Для каждого пакета следует назначить ответственного за него программиста, который будет сопровождать пакет и развивать его функциональность. Часть кода, реализующего общесистемную логику, например, унифицированную обработку ошибок и ведение журналов изменения данных, можно выделить в отдельную группу пакетов ядра прикладной системы (kernel packages), назначив ответственными за них самых опытных программистов.
Спецификация и тело пакета
Пакет PL/SQL состоит из двух объектов базы данных: спецификации пакета (PACKAGE) и тела пакета (PACKAGE BODY). Команда создания спецификации пакета имеет следующий синтаксис:
CREATE [OR REPLACE] PACKAGE [имя_схемы.]имя_пакета {IS | AS}
спецификация пакета
END;
Команда создания тела пакета имеет следующий синтаксис:
CREATE [OR REPLACE] PACKAGE BODY [имя_схемы.]имя_пакета {IS | AS}
[спецификация локальных элементов пакета]
блоки PL/SQL реализации процедур и функций, объявленных в спецификации
блоки PL/SQL локальных процедур и функций
[BEGIN секция инициализации пакета]
END;
В спецификации пакета находится описание следующих программных элементов, доступных из других программ PL/SQL (то есть элементов, видимых извне):
пользовательские типы данных;
пользовательские исключения;
процедуры и функции;
переменные;
константы;
курсоры.
Эти программные элементы называются глобальными пакетными переменными, глобальными пакетными курсорами и т. п.
Для процедур и функций в спецификации пакета присутствуют только заголовки – названия процедур и функций и описания их параметров. В спецификации пакета нет блоков PL/SQL, реализующих логику процедур и функций, вся она находится в теле пакета. Можно считать, что спецификация пакета является интерфейсной частью – аналогом заголовочных файлов (header files), имеющихся, например, в языке программирования C++.
В теле пакета могут быть объявлены все те же виды программных элементов, что и в спецификации пакета с той лишь разницей, что они не будут доступны из других программ PL/SQL (не видны извне тела пакета). Эти элементы называются локальными пакетными переменными, локальными пакетными процедурами и т. п.
Локальные программные элементы предназначены исключительно для использования только процедурами и функциями самого пакета. Тем самым в PL/SQL реализовано сокрытие, то есть принцип проектирования программного обеспечения, заключающийся в разграничении доступа различных программ к внутренним компонентам друг друга. Подчеркнем, разграничивается доступ именно к внутренним компонентам.
Покажем области видимости объявленных в пакетах переменных и программ:
CREATE OR REPLACE PACKAGE pkg1 AS
– g_var1 – глобальная пакетная переменная
– видна и в теле пакета и снаружи (причем может изменяться снаружи)
g_var1 INTEGER;
– глобальная пакетная процедура, видна и в теле пакета и снаружи
PROCEDURE proc1;
END;
CREATE OR REPLACE PACKAGE BODY pkg1 AS
– локальная переменная, видна внутри тела пакета, снаружи не видна
l_var2 DATE;
– локальная функция, видна внутри тела пакета, снаружи не видна
FUNCTION function1 RETURN VARCHAR2 IS
BEGIN
RETURN TO_CHAR(SYSDATE,'DD.MM.YYYY HH24:MI:SS');
END;
– реализация в теле логики процедуры proc1, объявленной в спецификации
PROCEDURE proc1 IS
– l_p_var3 – локальная переменная процедуры proc1
– видна только внутри процедуры proc1
l_p_var3 VARCHAR2(2000);
BEGIN
l_p_var3 := function1||' '||to_char(l_var2)||to_char(g_var1);
END;
END;
Достоинства использования пакетов
Сформулируем достоинства использования пакетов PL/SQL при разработке серверной бизнес-логики:
упрощение сопровождения и расширения программ PL/SQL, так как пакеты обеспечивают инкапсуляцию кода и позволяют группировать логически связанные процедуры и функции;
разграничение доступа различных пакетов к внутренним компонентам друг друга;
сохранение данных сессии пользователя в глобальных пакетных переменных, в том числе повышение производительности приложений за счет кэширования постоянно использующихся в программах PL/SQL данных, например, справочников (данные кэшируются в коллекциях-глобальных переменных пакетов);
исключение жестко кодируемых литералов (hard-coded literals).
Хороший стиль программирования на PL/SQL предусматривает даже для небольших проектов наличие спецификаций пакетов, в которых объявлены
все пользовательские типы данных;
все константы и переменные, которые инициализируются жестко кодируемыми литералами, в том числе магическими числами;
Читать дальше