forked from CITKParus/P8-Panels
ЦИТК-979 - Настройка запроса - аргументы (сервер)
This commit is contained in:
parent
a20de79a40
commit
abaf9455a9
@ -11,7 +11,7 @@ create table P8PNL_QE_QUERY
|
||||
CH_DATE date not null, -- Дата последнего изменения
|
||||
READY number(1) default 0 not null, -- Флаг готовности к использованию (0 - нет, 1 - да)
|
||||
PBL number(1) default 0 not null, -- Флаг публичности (0 - нет, 1 - да)
|
||||
OPTS clob, -- Параметры запроса
|
||||
OPT clob, -- Настройка запроса
|
||||
ENTS clob, -- Сущности запроса
|
||||
RLS clob, -- Отношения сущностей запроса
|
||||
QRY clob, -- Запрос
|
||||
|
||||
@ -1,5 +1,12 @@
|
||||
create or replace package PKG_P8PANELS_QE as
|
||||
|
||||
/* Получение данных о запросе */
|
||||
procedure QUERY
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
COUT out clob -- Сериализованное описание запроса
|
||||
);
|
||||
|
||||
/* Получение списка запросов */
|
||||
procedure QUERY_LIST
|
||||
(
|
||||
@ -28,11 +35,18 @@ create or replace package PKG_P8PANELS_QE as
|
||||
NRN in number -- Рег. номер запроса
|
||||
);
|
||||
|
||||
/* Получение данных о запросе */
|
||||
procedure QUERY_DESC
|
||||
/* Установка признака "готовности" запроса */
|
||||
procedure QUERY_READY_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
COUT out clob -- Сериализованное описание запроса
|
||||
NREADY in number -- Флаг готовности к использованию (0 - нет, 1 - да)
|
||||
);
|
||||
|
||||
/* Установка признака "публичности" запроса */
|
||||
procedure QUERY_PBL_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NPBL in number -- Флаг публичности (0 - приватный, 1 - публичный)
|
||||
);
|
||||
|
||||
/* Добавление сущности в запрос */
|
||||
@ -90,24 +104,51 @@ create or replace package PKG_P8PANELS_QE as
|
||||
SID in varchar2 -- Идентификатор связи
|
||||
);
|
||||
|
||||
/* Установка признака "готовности" запроса */
|
||||
procedure QUERY_READY_SET
|
||||
/* Добавление аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_ADD
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NREADY in number -- Флаг готовности к использованию (0 - нет, 1 - да)
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
);
|
||||
|
||||
/* Установка признака "публичности" запроса */
|
||||
procedure QUERY_PBL_SET
|
||||
/* Изменение аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_EDIT
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
);
|
||||
|
||||
/* Удаление аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_REMOVE
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NPBL in number -- Флаг публичности (0 - приватный, 1 - публичный)
|
||||
SNAME in varchar2 -- Имя
|
||||
);
|
||||
|
||||
end PKG_P8PANELS_QE;
|
||||
/
|
||||
create or replace package body PKG_P8PANELS_QE as
|
||||
|
||||
/* Получение описания запроса */
|
||||
procedure QUERY
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
COUT out clob -- Сериализованное описание запроса
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Проверим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_VIEW(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Получим описание запроса */
|
||||
COUT := PKG_P8PANELS_QE_BASE.QUERY(NRN => NRN);
|
||||
end QUERY;
|
||||
|
||||
/* Получение списка запросов */
|
||||
procedure QUERY_LIST
|
||||
(
|
||||
@ -116,7 +157,7 @@ create or replace package body PKG_P8PANELS_QE as
|
||||
is
|
||||
begin
|
||||
/* Базово сформируем список */
|
||||
COUT := PKG_P8PANELS_QE_BASE.QUERY_LIST_GET(SUSER => UTILIZER());
|
||||
COUT := PKG_P8PANELS_QE_BASE.QUERY_LIST(SUSER => UTILIZER());
|
||||
end QUERY_LIST;
|
||||
|
||||
/* Добавление запроса */
|
||||
@ -160,19 +201,33 @@ create or replace package body PKG_P8PANELS_QE as
|
||||
PKG_P8PANELS_QE_BASE.QUERY_DELETE(NRN => NRN);
|
||||
end QUERY_DELETE;
|
||||
|
||||
/* Получение описания запроса */
|
||||
procedure QUERY_DESC
|
||||
/* Установка признака "готовности" запроса */
|
||||
procedure QUERY_READY_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
COUT out clob -- Сериализованное описание запроса
|
||||
NREADY in number -- Флаг готовности к использованию (0 - нет, 1 - да)
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Проверим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_VIEW(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Получим описание запроса */
|
||||
COUT := PKG_P8PANELS_QE_BASE.QUERY_DESC_GET(NRN => NRN);
|
||||
end QUERY_DESC;
|
||||
/* Провим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_MODIFY(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Базовая установка признака готовности */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_READY_SET(NRN => NRN, NREADY => NREADY);
|
||||
end QUERY_READY_SET;
|
||||
|
||||
/* Установка признака "публичности" запроса */
|
||||
procedure QUERY_PBL_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NPBL in number -- Флаг публичности (0 - приватный, 1 - публичный)
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Провим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_MODIFY(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Базовая установка признака публичности */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_PBL_SET(NRN => NRN, NPBL => NPBL);
|
||||
end QUERY_PBL_SET;
|
||||
|
||||
/* Добавление сущности в запрос */
|
||||
procedure QUERY_ENT_ADD
|
||||
@ -192,7 +247,7 @@ create or replace package body PKG_P8PANELS_QE as
|
||||
/* Читаем существующие сущности */
|
||||
RENTS := PKG_P8PANELS_QE_BASE.QUERY_ENTS_GET(CENTS => RQ.ENTS);
|
||||
/* Формируем описание новой сущности и добавляем её в коллекцию */
|
||||
PKG_P8PANELS_QE_BASE.TENTS_APPEND(RENTS => RENTS, SNAME => SNAME, STYPE => STYPE);
|
||||
PKG_P8PANELS_QE_BASE.TENTS_ADD(RENTS => RENTS, SNAME => SNAME, STYPE => STYPE);
|
||||
/* Сохраняем обновленный набор сущностей */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ENTS_SET(NRN => RQ.RN, RENTS => RENTS);
|
||||
end QUERY_ENT_ADD;
|
||||
@ -357,7 +412,7 @@ create or replace package body PKG_P8PANELS_QE as
|
||||
/* Читаем существующие связи */
|
||||
RRLS := PKG_P8PANELS_QE_BASE.QUERY_RLS_GET(CRLS => RQ.RLS);
|
||||
/* Формируем описание новой связи и добавляем её в коллекцию */
|
||||
PKG_P8PANELS_QE_BASE.TRLS_APPEND(RRLS => RRLS, SSOURCE => SSOURCE, STARGET => STARGET);
|
||||
PKG_P8PANELS_QE_BASE.TRLS_ADD(RRLS => RRLS, SSOURCE => SSOURCE, STARGET => STARGET);
|
||||
/* Сохраняем обновленный набор связей */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_RLS_SET(NRN => RQ.RN, RRLS => RRLS);
|
||||
end QUERY_RL_ADD;
|
||||
@ -384,33 +439,102 @@ create or replace package body PKG_P8PANELS_QE as
|
||||
PKG_P8PANELS_QE_BASE.QUERY_RLS_SET(NRN => RQ.RN, RRLS => RRLS);
|
||||
end QUERY_RL_REMOVE;
|
||||
|
||||
/* Установка признака "готовности" запроса */
|
||||
procedure QUERY_READY_SET
|
||||
/* Добавление аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_ADD
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NREADY in number -- Флаг готовности к использованию (0 - нет, 1 - да)
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
)
|
||||
is
|
||||
RQ P8PNL_QE_QUERY%rowtype; -- Запись запроса
|
||||
ROPT PKG_P8PANELS_QE_BASE.TOPT; -- Настройка запроса
|
||||
begin
|
||||
/* Провим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_MODIFY(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Базовая установка признака готовности */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_READY_SET(NRN => NRN, NREADY => NREADY);
|
||||
end QUERY_READY_SET;
|
||||
/* Читаем запись запроса */
|
||||
RQ := PKG_P8PANELS_QE_BASE.QUERY_GET(NRN => NRN);
|
||||
/* Читаем текущую настройку */
|
||||
ROPT := PKG_P8PANELS_QE_BASE.QUERY_OPT_GET(COPT => RQ.OPT);
|
||||
/* Добавляем аргумент в коллекцию */
|
||||
PKG_P8PANELS_QE_BASE.TARGS_ADD(RARGS => ROPT.RARGS,
|
||||
SNAME => SNAME,
|
||||
STITLE => STITLE,
|
||||
NDATA_TYPE => NDATA_TYPE,
|
||||
NMANDATORY => NMANDATORY);
|
||||
/* Сохраняем обновленную настройку */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_OPT_SET(NRN => RQ.RN, ROPT => ROPT);
|
||||
end QUERY_OPT_ARG_ADD;
|
||||
|
||||
/* Установка признака "публичности" запроса */
|
||||
procedure QUERY_PBL_SET
|
||||
/* Изменение аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_EDIT
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
NPBL in number -- Флаг публичности (0 - приватный, 1 - публичный)
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
)
|
||||
is
|
||||
RQ P8PNL_QE_QUERY%rowtype; -- Запись запроса
|
||||
ROPT PKG_P8PANELS_QE_BASE.TOPT; -- Настройка запроса
|
||||
NINDEX PKG_STD.TNUMBER; -- Индекс изменяемого аргумента в коллекции
|
||||
begin
|
||||
/* Провим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_MODIFY(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Базовая установка признака публичности */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_PBL_SET(NRN => NRN, NPBL => NPBL);
|
||||
end QUERY_PBL_SET;
|
||||
/* Читаем запись запроса */
|
||||
RQ := PKG_P8PANELS_QE_BASE.QUERY_GET(NRN => NRN);
|
||||
/* Читаем текущую настройку */
|
||||
ROPT := PKG_P8PANELS_QE_BASE.QUERY_OPT_GET(COPT => RQ.OPT);
|
||||
/* Находим изменяемый аргумент */
|
||||
NINDEX := PKG_P8PANELS_QE_BASE.TARGS_INDEX_BY_NAME(RARGS => ROPT.RARGS, SNAME => SNAME);
|
||||
if (NINDEX is null) then
|
||||
P_EXCEPTION(0,
|
||||
'Аргумент с именем "%s" в запросе "%s" не определен.',
|
||||
COALESCE(SNAME, '<НЕ УКАЗАН>'),
|
||||
TO_CHAR(NRN));
|
||||
end if;
|
||||
/* Изменяем аргумент в коллекции */
|
||||
PKG_P8PANELS_QE_BASE.TARGS_EDIT(RARGS => ROPT.RARGS,
|
||||
NINDEX => NINDEX,
|
||||
SNAME => SNAME,
|
||||
STITLE => STITLE,
|
||||
NDATA_TYPE => NDATA_TYPE,
|
||||
NMANDATORY => NMANDATORY);
|
||||
/* Сохраняем обновленную настройку */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_OPT_SET(NRN => RQ.RN, ROPT => ROPT);
|
||||
end QUERY_OPT_ARG_EDIT;
|
||||
|
||||
/* Удаление аргумента запроса */
|
||||
procedure QUERY_OPT_ARG_REMOVE
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SNAME in varchar2 -- Имя
|
||||
)
|
||||
is
|
||||
RQ P8PNL_QE_QUERY%rowtype; -- Запись запроса
|
||||
ROPT PKG_P8PANELS_QE_BASE.TOPT; -- Настройка запроса
|
||||
begin
|
||||
/* Провим права доступа */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_ACCESS_MODIFY(NRN => NRN, SUSER => UTILIZER());
|
||||
/* Читаем запись запроса */
|
||||
RQ := PKG_P8PANELS_QE_BASE.QUERY_GET(NRN => NRN);
|
||||
/* Читаем текущую настройку */
|
||||
ROPT := PKG_P8PANELS_QE_BASE.QUERY_OPT_GET(COPT => RQ.OPT);
|
||||
/* Находим удаляемый аргумент */
|
||||
if (PKG_P8PANELS_QE_BASE.TARGS_INDEX_BY_NAME(RARGS => ROPT.RARGS, SNAME => SNAME) is null) then
|
||||
P_EXCEPTION(0,
|
||||
'Аргумент с именем "%s" в запросе "%s" не определен.',
|
||||
COALESCE(SNAME, '<НЕ УКАЗАН>'),
|
||||
TO_CHAR(NRN));
|
||||
end if;
|
||||
/* Удаляем аргумент из коллекции */
|
||||
PKG_P8PANELS_QE_BASE.TARGS_REMOVE(RARGS => ROPT.RARGS, SNAME => SNAME);
|
||||
/* Сохраняем обновленную настройку */
|
||||
PKG_P8PANELS_QE_BASE.QUERY_OPT_SET(NRN => RQ.RN, ROPT => ROPT);
|
||||
end QUERY_OPT_ARG_REMOVE;
|
||||
|
||||
end PKG_P8PANELS_QE;
|
||||
/
|
||||
|
||||
@ -1,5 +1,24 @@
|
||||
create or replace package PKG_P8PANELS_QE_BASE as
|
||||
|
||||
/* Типы данных - Аргумент */
|
||||
type TARG is record
|
||||
(
|
||||
SNAME PKG_STD.TSTRING, -- Имя
|
||||
STITLE PKG_STD.TSTRING, -- Заголовок
|
||||
NDATA_TYPE PKG_STD.TNUMBER, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY PKG_STD.TNUMBER -- Флаг обязательности (1 - да, 0 - нет)
|
||||
);
|
||||
|
||||
/* Типы данных - Коллекция аргументов */
|
||||
type TARGS is table of TARG;
|
||||
|
||||
/* Типы данных - Настройка запроса */
|
||||
type TOPT is record
|
||||
(
|
||||
RARGS TARGS, -- Аргументы
|
||||
SCOND PKG_STD.TSTRING -- Условия отбора
|
||||
);
|
||||
|
||||
/* Типы данных - Атрибут сущности */
|
||||
type TATTR is record
|
||||
(
|
||||
@ -50,6 +69,41 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
BADD_ROOT in boolean := false -- Флаг необходимости добавления корневого тэга (false - нет, true - да)
|
||||
) return TATTRS; -- Коллекция атрибутов сущности
|
||||
|
||||
/* Поиск индекса аргумента по имени */
|
||||
function TARGS_INDEX_BY_NAME
|
||||
(
|
||||
RARGS in TARGS, -- Коллекция аргументов
|
||||
SNAME in varchar2 -- Искомое имя
|
||||
) return number; -- Индекс найденного аргумента (null - если не найдено)
|
||||
|
||||
/* Добавление аргумента в коллекцию */
|
||||
procedure TARGS_ADD
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
);
|
||||
|
||||
/* Изменение аргумента в коллекции */
|
||||
procedure TARGS_EDIT
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
NINDEX in number, -- Индекс изменяемого аргумента
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
);
|
||||
|
||||
/* Удаление аргумента из коллекции */
|
||||
procedure TARGS_REMOVE
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
SNAME in varchar2 -- Имя удаляемого аргумента
|
||||
);
|
||||
|
||||
/* Поиск индекса сущности по идентификатору */
|
||||
function TENTS_INDEX_BY_ID
|
||||
(
|
||||
@ -58,7 +112,7 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
) return number; -- Индекс найденной сущности (null - если не найдено)
|
||||
|
||||
/* Добавление сущности в коллекцию */
|
||||
procedure TENTS_APPEND
|
||||
procedure TENTS_ADD
|
||||
(
|
||||
RENTS in out nocopy TENTS, -- Изменяемая коллекция
|
||||
SNAME in varchar2, -- Имя
|
||||
@ -82,7 +136,7 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
);
|
||||
|
||||
/* Добавление связи в коллекцию */
|
||||
procedure TRLS_APPEND
|
||||
procedure TRLS_ADD
|
||||
(
|
||||
RRLS in out nocopy TRLS, -- Изменяемая коллекция
|
||||
SSOURCE in varchar2, -- Источник
|
||||
@ -109,7 +163,7 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
NRN in number -- Рег. номер запроса
|
||||
) return P8PNL_QE_QUERY%rowtype; -- Запись запроса
|
||||
|
||||
/* Получение признака возможности изменения запроса */
|
||||
/* Получение признака возможности изменения запроса */
|
||||
function QUERY_ACCESS_SIGN_MODIFY
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
@ -137,6 +191,18 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
SUSER in varchar2 -- Имя пользователя
|
||||
);
|
||||
|
||||
/* Формирование описания запроса */
|
||||
function QUERY
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
) return clob; -- XML-описание
|
||||
|
||||
/* Формирование списка запросов */
|
||||
function QUERY_LIST
|
||||
(
|
||||
SUSER in varchar2 -- Имя пользователя
|
||||
) return clob; -- Список запросов
|
||||
|
||||
/* Добавление запроса */
|
||||
procedure QUERY_INSERT
|
||||
(
|
||||
@ -159,18 +225,6 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
NRN in number -- Рег. номер запроса
|
||||
);
|
||||
|
||||
/* Формирование списка запросов */
|
||||
function QUERY_LIST_GET
|
||||
(
|
||||
SUSER in varchar2 -- Имя пользователя
|
||||
) return clob; -- Список запросов
|
||||
|
||||
/* Получение описания запроса */
|
||||
function QUERY_DESC_GET
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
) return clob; -- XML-описание
|
||||
|
||||
/* Чтение сущностей запроса */
|
||||
function QUERY_ENTS_GET
|
||||
(
|
||||
@ -219,6 +273,19 @@ create or replace package PKG_P8PANELS_QE_BASE as
|
||||
NPBL in number -- Флаг публичности (0 - приватный, 1 - публичный)
|
||||
);
|
||||
|
||||
/* Чтение настройки запроса */
|
||||
function QUERY_OPT_GET
|
||||
(
|
||||
COPT in clob -- Сериализованное описание настройки запроса
|
||||
) return TOPT; -- Настройка запроса
|
||||
|
||||
/* Запись настройки запроса */
|
||||
procedure QUERY_OPT_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
ROPT in TOPT -- Настройка запроса
|
||||
);
|
||||
|
||||
end PKG_P8PANELS_QE_BASE;
|
||||
/
|
||||
create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
@ -231,36 +298,43 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
STAG_DATA constant PKG_STD.TSTRING := 'XDATA'; -- Данные
|
||||
STAG_QUERIES constant PKG_STD.TSTRING := 'XQUERIES'; -- Запросы
|
||||
STAG_QUERY constant PKG_STD.TSTRING := 'XQUERY'; -- Запрос
|
||||
STAG_ARGS constant PKG_STD.TSTRING := 'XARGS'; -- Аргументы запроса
|
||||
STAG_ARG constant PKG_STD.TSTRING := 'XARG'; -- Аргумент запроса
|
||||
STAG_ATTRS constant PKG_STD.TSTRING := 'XATTRS'; -- Атрибуты сущности
|
||||
STAG_ATTR constant PKG_STD.TSTRING := 'XATTR'; -- Атрибут сущности
|
||||
STAG_ENTS constant PKG_STD.TSTRING := 'XENTS'; -- Сущности
|
||||
STAG_ENT constant PKG_STD.TSTRING := 'XENT'; -- Сущность
|
||||
STAG_RLS constant PKG_STD.TSTRING := 'XRLS'; -- Связи
|
||||
STAG_RL constant PKG_STD.TSTRING := 'XRL'; -- Связь
|
||||
STAG_OPTS constant PKG_STD.TSTRING := 'XOPTS'; -- Параметры
|
||||
STAG_OPT constant PKG_STD.TSTRING := 'XOPT'; -- Параметр
|
||||
STAG_OPT constant PKG_STD.TSTRING := 'XOPT'; -- Настройка запроса
|
||||
STAG_COND constant PKG_STD.TSTRING := 'XCOND'; -- Условия запроса
|
||||
|
||||
/* Константы - Атрибуты для сериализации */
|
||||
SATTR_ID constant PKG_STD.TSTRING := 'id'; -- Идентификатор
|
||||
SATTR_RN constant PKG_STD.TSTRING := 'rn'; -- Регистрационный номер
|
||||
SATTR_CODE constant PKG_STD.TSTRING := 'code'; -- Код
|
||||
SATTR_NAME constant PKG_STD.TSTRING := 'name'; -- Имя
|
||||
SATTR_AUTHOR constant PKG_STD.TSTRING := 'author'; -- Автор
|
||||
SATTR_CH_DATE constant PKG_STD.TSTRING := 'chDate'; -- Дата изменения
|
||||
SATTR_READY constant PKG_STD.TSTRING := 'ready'; -- Готовность к использованию
|
||||
SATTR_PBL constant PKG_STD.TSTRING := 'pbl'; -- Публичность
|
||||
SATTR_MODIFY constant PKG_STD.TSTRING := 'modify'; -- Изменяемость
|
||||
SATTR_TITLE constant PKG_STD.TSTRING := 'title'; -- Заголовок
|
||||
SATTR_TYPE constant PKG_STD.TSTRING := 'type'; -- Тип
|
||||
SATTR_DATA_TYPE constant PKG_STD.TSTRING := 'dataType'; -- Тип данных
|
||||
SATTR_X constant PKG_STD.TSTRING := 'x'; -- Координата по X
|
||||
SATTR_Y constant PKG_STD.TSTRING := 'y'; -- Координата по Y
|
||||
SATTR_SOURCE constant PKG_STD.TSTRING := 'source'; -- Источник
|
||||
SATTR_TARGET constant PKG_STD.TSTRING := 'target'; -- Приёмник
|
||||
SATTR_AGG constant PKG_STD.TSTRING := 'agg'; -- Агрегатная функция
|
||||
SATTR_ALIAS constant PKG_STD.TSTRING := 'alias'; -- Псевдоним
|
||||
SATTR_USE constant PKG_STD.TSTRING := 'use'; -- Применение в запросе
|
||||
SATTR_SHOW constant PKG_STD.TSTRING := 'show'; -- Отображение в запросе
|
||||
SATTR_ID constant PKG_STD.TSTRING := 'id'; -- Идентификатор
|
||||
SATTR_RN constant PKG_STD.TSTRING := 'rn'; -- Регистрационный номер
|
||||
SATTR_CODE constant PKG_STD.TSTRING := 'code'; -- Код
|
||||
SATTR_NAME constant PKG_STD.TSTRING := 'name'; -- Имя
|
||||
SATTR_AUTHOR constant PKG_STD.TSTRING := 'author'; -- Автор
|
||||
SATTR_CH_DATE constant PKG_STD.TSTRING := 'chDate'; -- Дата изменения
|
||||
SATTR_READY constant PKG_STD.TSTRING := 'ready'; -- Готовность к использованию
|
||||
SATTR_PBL constant PKG_STD.TSTRING := 'pbl'; -- Публичность
|
||||
SATTR_MODIFY constant PKG_STD.TSTRING := 'modify'; -- Изменяемость
|
||||
SATTR_TITLE constant PKG_STD.TSTRING := 'title'; -- Заголовок
|
||||
SATTR_TYPE constant PKG_STD.TSTRING := 'type'; -- Тип
|
||||
SATTR_DATA_TYPE constant PKG_STD.TSTRING := 'dataType'; -- Тип данных
|
||||
SATTR_MANDATORY constant PKG_STD.TSTRING := 'mandatory'; -- Обязательность
|
||||
SATTR_X constant PKG_STD.TSTRING := 'x'; -- Координата по X
|
||||
SATTR_Y constant PKG_STD.TSTRING := 'y'; -- Координата по Y
|
||||
SATTR_SOURCE constant PKG_STD.TSTRING := 'source'; -- Источник
|
||||
SATTR_TARGET constant PKG_STD.TSTRING := 'target'; -- Приёмник
|
||||
SATTR_AGG constant PKG_STD.TSTRING := 'agg'; -- Агрегатная функция
|
||||
SATTR_ALIAS constant PKG_STD.TSTRING := 'alias'; -- Псевдоним
|
||||
SATTR_USE constant PKG_STD.TSTRING := 'use'; -- Применение в запросе
|
||||
SATTR_SHOW constant PKG_STD.TSTRING := 'show'; -- Отображение в запросе
|
||||
|
||||
/* Константы - зарезервированные имена рагументов */
|
||||
SARG_NAME_PAGE constant PKG_STD.TSTRING := 'NPAGE'; -- Номер страницы
|
||||
SARG_NAME_PAGE_SIZE constant PKG_STD.TSTRING := 'NPAGE_SIZE'; -- Размер страницы (записей)
|
||||
|
||||
/* Получение заголовка представления из метаданных */
|
||||
function DMSCLVIEWS_TITLE_GET
|
||||
@ -317,6 +391,351 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
return SATTR_NAME;
|
||||
end DMSCLVIEWSATTRS_TITLE_GET;
|
||||
|
||||
/* Формирование аргумента */
|
||||
function TARG_MAKE
|
||||
(
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
) return TARG -- Описание аргумента
|
||||
is
|
||||
RARG TARG; -- Буфер для результата
|
||||
begin
|
||||
/* Проверим имя */
|
||||
if (SNAME is null) then
|
||||
P_EXCEPTION(0, 'Имя аргумента не указано.');
|
||||
end if;
|
||||
for C in (select null from DUAL where not REGEXP_LIKE(SNAME, '^[A-z0-9_]+$'))
|
||||
loop
|
||||
P_EXCEPTION(0,
|
||||
'Имя аргумента содержит недопустимые символы (разрешены латинские буквы, цифры и символ нижнего подчеркивания).');
|
||||
end loop;
|
||||
if (UPPER(SNAME) in (UPPER(SARG_NAME_PAGE), UPPER(SARG_NAME_PAGE_SIZE))) then
|
||||
P_EXCEPTION(0, 'Это имя аргумента зарезервировано Системой.');
|
||||
end if;
|
||||
/* Проверим заголовок */
|
||||
if (STITLE is null) then
|
||||
P_EXCEPTION(0, 'Не указан заголовок аргумента.');
|
||||
end if;
|
||||
/* Проверим корректность типа сущности */
|
||||
if (NDATA_TYPE is null) then
|
||||
P_EXCEPTION(0, 'Не указан тип данных аргумента.');
|
||||
end if;
|
||||
if (NDATA_TYPE not in (PKG_STD.DATA_TYPE_STR, PKG_STD.DATA_TYPE_NUM, PKG_STD.DATA_TYPE_DATE)) then
|
||||
P_EXCEPTION(0,
|
||||
'Аргументы типа "%s" не поддерживаются.',
|
||||
COALESCE(TO_CHAR(NDATA_TYPE), '<НЕ УКАЗАН>'));
|
||||
end if;
|
||||
/* Проверим корректность флага обязательности */
|
||||
if (NMANDATORY is null) then
|
||||
P_EXCEPTION(0, 'Не указан признак обязательности аргумента.');
|
||||
end if;
|
||||
if (NMANDATORY not in (0, 1)) then
|
||||
P_EXCEPTION(0,
|
||||
'Некорректно указан признак обязательности аргумента.');
|
||||
end if;
|
||||
/* Собираем аргумент */
|
||||
RARG.SNAME := UPPER(SNAME);
|
||||
RARG.STITLE := STITLE;
|
||||
RARG.NDATA_TYPE := NDATA_TYPE;
|
||||
RARG.NMANDATORY := NMANDATORY;
|
||||
/* Вернем полученное */
|
||||
return RARG;
|
||||
end TARG_MAKE;
|
||||
|
||||
/* Сериализация аргумента */
|
||||
procedure TARG_TO_XML
|
||||
(
|
||||
RARG in TARG -- Аргумент
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Открываем описание аргумента */
|
||||
PKG_XFAST.DOWN_NODE(SNAME => STAG_ARG);
|
||||
/* Аргумент */
|
||||
PKG_XFAST.ATTR(SNAME => SATTR_NAME, SVALUE => RARG.SNAME);
|
||||
PKG_XFAST.ATTR(SNAME => SATTR_TITLE, SVALUE => RARG.STITLE);
|
||||
PKG_XFAST.ATTR(SNAME => SATTR_DATA_TYPE, NVALUE => RARG.NDATA_TYPE);
|
||||
PKG_XFAST.ATTR(SNAME => SATTR_MANDATORY, NVALUE => RARG.NMANDATORY);
|
||||
/* Закрываем описание аргумента */
|
||||
PKG_XFAST.UP();
|
||||
end TARG_TO_XML;
|
||||
|
||||
/* Десериализация аргумента */
|
||||
function TARG_FROM_XML
|
||||
(
|
||||
CXML in clob -- XML-описание аргумента
|
||||
) return TARG -- Аргумент
|
||||
is
|
||||
RRES TARG; -- Буфер для результата
|
||||
XDOC PKG_XPATH.TDOCUMENT; -- Документ XML
|
||||
XROOT PKG_XPATH.TNODE; -- Корень документа XML
|
||||
XNODE PKG_XPATH.TNODE; -- Буфер узла документа
|
||||
begin
|
||||
/* Если данные есть */
|
||||
if (CXML is not null) then
|
||||
begin
|
||||
/* Разбираем XML */
|
||||
XDOC := PKG_XPATH.PARSE_FROM_CLOB(LCXML => CXML);
|
||||
/* Считываем корневой узел */
|
||||
XROOT := PKG_XPATH.ROOT_NODE(RDOCUMENT => XDOC);
|
||||
XNODE := PKG_XPATH.SINGLE_NODE(RPARENT_NODE => XROOT, SPATTERN => '/' || STAG_ARG);
|
||||
/* Получаем значения */
|
||||
RRES.SNAME := PKG_XPATH.ATTRIBUTE(RNODE => XNODE, SNAME => SATTR_NAME);
|
||||
RRES.STITLE := PKG_XPATH.ATTRIBUTE(RNODE => XNODE, SNAME => SATTR_TITLE);
|
||||
RRES.NDATA_TYPE := PKG_XPATH.ATTRIBUTE_NUM(RNODE => XNODE, SNAME => SATTR_DATA_TYPE);
|
||||
RRES.NMANDATORY := PKG_XPATH.ATTRIBUTE_NUM(RNODE => XNODE, SNAME => SATTR_MANDATORY);
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
exception
|
||||
when others then
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end;
|
||||
end if;
|
||||
/* Вернём результат */
|
||||
return RRES;
|
||||
end TARG_FROM_XML;
|
||||
|
||||
/* Поиск индекса аргумента по имени */
|
||||
function TARGS_INDEX_BY_NAME
|
||||
(
|
||||
RARGS in TARGS, -- Коллекция аргументов
|
||||
SNAME in varchar2 -- Искомое имя
|
||||
) return number -- Индекс найденного аргумента (null - если не найдено)
|
||||
is
|
||||
begin
|
||||
/* Обходим коллекцию */
|
||||
if ((RARGS is not null) and (RARGS.COUNT > 0)) then
|
||||
for I in RARGS.FIRST .. RARGS.LAST
|
||||
loop
|
||||
begin
|
||||
/* Возвращаем найденный индекс */
|
||||
if (RARGS(I).SNAME = SNAME) then
|
||||
return I;
|
||||
end if;
|
||||
exception
|
||||
when NO_DATA_FOUND then
|
||||
null;
|
||||
end;
|
||||
end loop;
|
||||
end if;
|
||||
/* Ничего не нашли */
|
||||
return null;
|
||||
end TARGS_INDEX_BY_NAME;
|
||||
|
||||
/* Добавление аргумента в коллекцию */
|
||||
procedure TARGS_ADD
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
)
|
||||
is
|
||||
RARG TARG; -- Добавляемый аргумент
|
||||
begin
|
||||
/* Инициализируем коллекцию если необходимо */
|
||||
if (RARGS is null) then
|
||||
RARGS := TARGS();
|
||||
end if;
|
||||
/* Проверим уникальность имени */
|
||||
if ((SNAME is not null) and (TARGS_INDEX_BY_NAME(RARGS => RARGS, SNAME => SNAME) is not null)) then
|
||||
P_EXCEPTION(0, 'Аргумент с именем "%s" уже существует.', SNAME);
|
||||
end if;
|
||||
/* Формируем аргумент */
|
||||
RARG := TARG_MAKE(SNAME => SNAME, STITLE => STITLE, NDATA_TYPE => NDATA_TYPE, NMANDATORY => NMANDATORY);
|
||||
/* Добавляем его в коллекцию */
|
||||
RARGS.EXTEND();
|
||||
RARGS(RARGS.LAST) := RARG;
|
||||
end TARGS_ADD;
|
||||
|
||||
/* Изменение аргумента в коллекции */
|
||||
procedure TARGS_EDIT
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
NINDEX in number, -- Индекс изменяемого аргумента
|
||||
SNAME in varchar2, -- Имя
|
||||
STITLE in varchar2, -- Заголовок
|
||||
NDATA_TYPE in number, -- Тип данных (см. константы PKG_STD.DATA_TYPE_*)
|
||||
NMANDATORY in number -- Флаг обязательности (1 - да, 0 - нет)
|
||||
)
|
||||
is
|
||||
RARG TARG; -- Добавляемый аргумент
|
||||
begin
|
||||
/* Проверим коллекцию */
|
||||
if ((RARGS is null) or (RARGS.COUNT = 0)) then
|
||||
P_EXCEPTION(0,
|
||||
'Коллекция аргументов пуста. Изменение аргумента невозможно.');
|
||||
end if;
|
||||
/* Проверим индекс изменяемого аргумента */
|
||||
if (NINDEX is null) then
|
||||
P_EXCEPTION(0, 'Не указан индекс изменяемого аргумента.');
|
||||
end if;
|
||||
/* Формируем аргумент */
|
||||
RARG := TARG_MAKE(SNAME => SNAME, STITLE => STITLE, NDATA_TYPE => NDATA_TYPE, NMANDATORY => NMANDATORY);
|
||||
/* Обновляем аргумент в коллекции */
|
||||
begin
|
||||
RARGS(NINDEX) := RARG;
|
||||
exception
|
||||
when others then
|
||||
P_EXCEPTION(0, 'Изменяемый аргумент отсутствует в коллекции.');
|
||||
end;
|
||||
end TARGS_EDIT;
|
||||
|
||||
/* Удаление аргумента из коллекции */
|
||||
procedure TARGS_REMOVE
|
||||
(
|
||||
RARGS in out nocopy TARGS, -- Изменяемая коллекция
|
||||
SNAME in varchar2 -- Имя удаляемого аргумента
|
||||
)
|
||||
is
|
||||
NIND PKG_STD.TNUMBER; -- Индекс аргумента коллекции
|
||||
begin
|
||||
/* Найдем индекс аргумента в коллекции */
|
||||
NIND := TARGS_INDEX_BY_NAME(RARGS => RARGS, SNAME => SNAME);
|
||||
/* Удалим его, если нашли */
|
||||
if (NIND is not null) then
|
||||
RARGS.DELETE(NIND);
|
||||
end if;
|
||||
end TARGS_REMOVE;
|
||||
|
||||
/* Сериализация коллекции аргументов */
|
||||
procedure TARGS_TO_XML
|
||||
(
|
||||
RARGS in TARGS -- Коллекция аргументов
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Открываем описание аргументов */
|
||||
PKG_XFAST.DOWN_NODE(SNAME => STAG_ARGS);
|
||||
/* Обходим аргументы из коллекции */
|
||||
if ((RARGS is not null) and (RARGS.COUNT > 0)) then
|
||||
for I in RARGS.FIRST .. RARGS.LAST
|
||||
loop
|
||||
begin
|
||||
/* Добавляем описание аргумента */
|
||||
TARG_TO_XML(RARG => RARGS(I));
|
||||
exception
|
||||
when NO_DATA_FOUND then
|
||||
null;
|
||||
end;
|
||||
end loop;
|
||||
end if;
|
||||
/* Закрываем описание аргумента */
|
||||
PKG_XFAST.UP();
|
||||
end TARGS_TO_XML;
|
||||
|
||||
/* Десериализация коллекции аргументов */
|
||||
function TARGS_FROM_XML
|
||||
(
|
||||
CXML in clob -- XML-описание коллекции аргументов
|
||||
) return TARGS -- Коллекция аргументов
|
||||
is
|
||||
RRES TARGS; -- Буфер для результата
|
||||
XDOC PKG_XPATH.TDOCUMENT; -- Документ XML
|
||||
XROOT PKG_XPATH.TNODE; -- Корень документа XML
|
||||
XNODE PKG_XPATH.TNODE; -- Буфер узла документа
|
||||
XNODES PKG_XPATH.TNODES; -- Буфер коллекции узлов документа
|
||||
begin
|
||||
/* Инициализируем результат */
|
||||
RRES := TARGS();
|
||||
/* Если данные есть */
|
||||
if (CXML is not null) then
|
||||
begin
|
||||
/* Разбираем XML */
|
||||
XDOC := PKG_XPATH.PARSE_FROM_CLOB(LCXML => CXML);
|
||||
/* Считываем корневой узел */
|
||||
XROOT := PKG_XPATH.ROOT_NODE(RDOCUMENT => XDOC);
|
||||
/* Считывание списка аргументов */
|
||||
XNODES := PKG_XPATH.LIST_NODES(RPARENT_NODE => XROOT, SPATTERN => '/' || STAG_ARGS || '/' || STAG_ARG);
|
||||
/* Цикл по списку аргументов */
|
||||
for I in 1 .. PKG_XPATH.COUNT_NODES(RNODES => XNODES)
|
||||
loop
|
||||
/* Считаем элемент по его номеру */
|
||||
XNODE := PKG_XPATH.ITEM_NODE(RNODES => XNODES, INUMBER => I);
|
||||
/* Сериализуем и добавим его в коллекцию */
|
||||
RRES.EXTEND();
|
||||
RRES(RRES.LAST) := TARG_FROM_XML(CXML => PKG_XPATH.SERIALIZE_TO_CLOB(RNODE => XNODE));
|
||||
end loop;
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
exception
|
||||
when others then
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end;
|
||||
end if;
|
||||
/* Вернём результат */
|
||||
return RRES;
|
||||
end TARGS_FROM_XML;
|
||||
|
||||
/* Сериализация настройки */
|
||||
procedure TOPT_TO_XML
|
||||
(
|
||||
ROPT in TOPT -- Настройка
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Открываем описание настройки */
|
||||
PKG_XFAST.DOWN_NODE(SNAME => STAG_OPT);
|
||||
/* Аргументы */
|
||||
TARGS_TO_XML(RARGS => ROPT.RARGS);
|
||||
/* Условия отбора */
|
||||
PKG_XFAST.HERB(SNAME => STAG_COND, SVALUE => ROPT.SCOND);
|
||||
/* Закрываем описание настройки */
|
||||
PKG_XFAST.UP();
|
||||
end TOPT_TO_XML;
|
||||
|
||||
/* Десериализация настройки */
|
||||
function TOPT_FROM_XML
|
||||
(
|
||||
CXML in clob -- XML-описание настройки
|
||||
) return TOPT -- Настройка
|
||||
is
|
||||
RRES TOPT; -- Буфер для результата
|
||||
XDOC PKG_XPATH.TDOCUMENT; -- Документ XML
|
||||
XROOT PKG_XPATH.TNODE; -- Корень документа XML
|
||||
XNODE PKG_XPATH.TNODE; -- Буфер узла документа
|
||||
begin
|
||||
/* Инициализируем настройку */
|
||||
RRES.RARGS := TARGS();
|
||||
/* Если данные есть */
|
||||
if (CXML is not null) then
|
||||
begin
|
||||
/* Разбираем XML */
|
||||
XDOC := PKG_XPATH.PARSE_FROM_CLOB(LCXML => CXML);
|
||||
/* Считываем корневой узел */
|
||||
XROOT := PKG_XPATH.ROOT_NODE(RDOCUMENT => XDOC);
|
||||
/* Считаваем узел настройки */
|
||||
XNODE := PKG_XPATH.SINGLE_NODE(RPARENT_NODE => XROOT, SPATTERN => '/' || STAG_OPT);
|
||||
/* Получаем значения */
|
||||
RRES.SCOND := PKG_XPATH.VALUE(RNODE => XNODE, SPATTERN => STAG_COND);
|
||||
RRES.RARGS := TARGS_FROM_XML(CXML => PKG_XPATH.SERIALIZE_TO_CLOB(RNODE => PKG_XPATH.SINGLE_NODE(RPARENT_NODE => XNODE,
|
||||
SPATTERN => STAG_ARGS)));
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
exception
|
||||
when others then
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end;
|
||||
end if;
|
||||
/* Вернём результат */
|
||||
return RRES;
|
||||
end TOPT_FROM_XML;
|
||||
|
||||
/* Формирование идентификатора атрибута сущности */
|
||||
function TATTR_ID_MAKE
|
||||
(
|
||||
@ -443,6 +862,9 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
BINIT boolean := false; -- Признак инициализации атрибутов сущности
|
||||
begin
|
||||
/* Проверим корректность типа сущности */
|
||||
if (RENT.STYPE is null) then
|
||||
P_EXCEPTION(0, 'Не указан тип сущности.');
|
||||
end if;
|
||||
if (RENT.STYPE not in (SENT_TYPE_TABLE, SENT_TYPE_VIEW)) then
|
||||
P_EXCEPTION(0,
|
||||
'Сущности типа "%s" не поддерживаются.',
|
||||
@ -635,6 +1057,9 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
RVIEW PKG_OBJECT_DESC.TVIEW; -- Описание представления
|
||||
begin
|
||||
/* Проверим корректность типа сущности */
|
||||
if (STYPE is null) then
|
||||
P_EXCEPTION(0, 'Не указан тип сущности.');
|
||||
end if;
|
||||
if (STYPE not in (SENT_TYPE_TABLE, SENT_TYPE_VIEW)) then
|
||||
P_EXCEPTION(0,
|
||||
'Сущности типа "%s" не поддерживаются.',
|
||||
@ -775,7 +1200,7 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
end TENTS_NEXT_NUMB;
|
||||
|
||||
/* Добавление сущности в коллекцию */
|
||||
procedure TENTS_APPEND
|
||||
procedure TENTS_ADD
|
||||
(
|
||||
RENTS in out nocopy TENTS, -- Изменяемая коллекция
|
||||
SNAME in varchar2, -- Имя
|
||||
@ -793,7 +1218,7 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
/* Добавляем её в коллекцию */
|
||||
RENTS.EXTEND();
|
||||
RENTS(RENTS.LAST) := RENT;
|
||||
end TENTS_APPEND;
|
||||
end TENTS_ADD;
|
||||
|
||||
/* Удаление сущности из коллекции */
|
||||
procedure TENTS_REMOVE
|
||||
@ -804,7 +1229,9 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
is
|
||||
NIND PKG_STD.TNUMBER; -- Индекс сущности в коллекции
|
||||
begin
|
||||
/* Найдем индекс сущности в коллекции */
|
||||
NIND := TENTS_INDEX_BY_ID(RENTS => RENTS, SID => SID);
|
||||
/* Удалим её, если нашли */
|
||||
if (NIND is not null) then
|
||||
RENTS.DELETE(NIND);
|
||||
end if;
|
||||
@ -1055,7 +1482,7 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
end TRLS_LIST_BY_ST;
|
||||
|
||||
/* Добавление связи в коллекцию */
|
||||
procedure TRLS_APPEND
|
||||
procedure TRLS_ADD
|
||||
(
|
||||
RRLS in out nocopy TRLS, -- Изменяемая коллекция
|
||||
SSOURCE in varchar2, -- Источник
|
||||
@ -1073,7 +1500,7 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
/* Добавляем её в коллекцию */
|
||||
RRLS.EXTEND();
|
||||
RRLS(RRLS.LAST) := RRL;
|
||||
end TRLS_APPEND;
|
||||
end TRLS_ADD;
|
||||
|
||||
/* Удаление связи из коллекции */
|
||||
procedure TRLS_REMOVE
|
||||
@ -1084,7 +1511,9 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
is
|
||||
NIND PKG_STD.TNUMBER; -- Индекс связи в коллекции
|
||||
begin
|
||||
/* Найдем индекс связи в коллекции */
|
||||
NIND := TRLS_INDEX_BY_ID(RRLS => RRLS, SID => SID);
|
||||
/* Удалим её, если нашли */
|
||||
if (NIND is not null) then
|
||||
RRLS.DELETE(NIND);
|
||||
end if;
|
||||
@ -1302,65 +1731,6 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
end if;
|
||||
end QUERY_CH_DATE_SYNC;
|
||||
|
||||
/* Добавление запроса */
|
||||
procedure QUERY_INSERT
|
||||
(
|
||||
SCODE in varchar2, -- Мнемокод
|
||||
SNAME in varchar2, -- Наименование
|
||||
NRN out number -- Рег. номер добавленного запроса
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Проверим параметры */
|
||||
QUERY_CHECK(SCODE => SCODE, SNAME => SNAME);
|
||||
/* Формируем рег. номер */
|
||||
NRN := GEN_ID();
|
||||
/* Добавляем данные */
|
||||
insert into P8PNL_QE_QUERY
|
||||
(RN, CODE, name, AUTHOR, CH_DATE, READY, PBL)
|
||||
values
|
||||
(NRN, SCODE, SNAME, UTILIZER(), sysdate, 0, 0);
|
||||
end QUERY_INSERT;
|
||||
|
||||
/* Исправление запроса */
|
||||
procedure QUERY_UPDATE
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SCODE in varchar2, -- Мнемокод
|
||||
SNAME in varchar2 -- Наименование
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Проверим параметры */
|
||||
QUERY_CHECK(SCODE => SCODE, SNAME => SNAME);
|
||||
/* Изменяем данные */
|
||||
update P8PNL_QE_QUERY T
|
||||
set T.CODE = SCODE,
|
||||
T.NAME = SNAME
|
||||
where T.RN = NRN;
|
||||
/* Контроль изменения данных */
|
||||
if (sql%notfound) then
|
||||
PKG_MSG.RECORD_NOT_FOUND(NDOCUMENT => NRN, SUNIT_TABLE => 'P8PNL_QE_QUERY');
|
||||
end if;
|
||||
/* Обновим дату изменения запроса */
|
||||
QUERY_CH_DATE_SYNC(NRN => NRN);
|
||||
end QUERY_UPDATE;
|
||||
|
||||
/* Удаление запроса */
|
||||
procedure QUERY_DELETE
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Удаляем запись */
|
||||
delete from P8PNL_QE_QUERY T where T.RN = NRN;
|
||||
/* Контроль изменения данных */
|
||||
if (sql%notfound) then
|
||||
PKG_MSG.RECORD_NOT_FOUND(NDOCUMENT => NRN, SUNIT_TABLE => 'P8PNL_QE_QUERY');
|
||||
end if;
|
||||
end QUERY_DELETE;
|
||||
|
||||
/* Сериализация сущностей запроса */
|
||||
function QUERY_ENTS_TO_XML
|
||||
(
|
||||
@ -1503,6 +1873,72 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
return RRLS;
|
||||
end QUERY_RLS_FROM_XML;
|
||||
|
||||
/* Сериализация настройки запроса */
|
||||
function QUERY_OPT_TO_XML
|
||||
(
|
||||
ROPT in TOPT -- Настройка
|
||||
) return clob -- XML-описание
|
||||
is
|
||||
CRES clob; -- Буфер для результата
|
||||
begin
|
||||
/* Начинаем формирование XML */
|
||||
PKG_XFAST.PROLOGUE(ITYPE => PKG_XFAST.CONTENT_);
|
||||
/* Формируем XML настройки */
|
||||
TOPT_TO_XML(ROPT => ROPT);
|
||||
/* Сериализуем */
|
||||
CRES := PKG_XFAST.SERIALIZE_TO_CLOB();
|
||||
/* Завершаем формирование XML */
|
||||
PKG_XFAST.EPILOGUE();
|
||||
/* Возвращаем полученное */
|
||||
return CRES;
|
||||
exception
|
||||
when others then
|
||||
/* Завершаем формирование XML */
|
||||
PKG_XFAST.EPILOGUE();
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end QUERY_OPT_TO_XML;
|
||||
|
||||
/* Десериализация настройки запроса */
|
||||
function QUERY_OPT_FROM_XML
|
||||
(
|
||||
CXML in clob -- XML-описание настройки запроса
|
||||
) return TOPT -- Настройка
|
||||
is
|
||||
ROPT TOPT; -- Буфер для результата
|
||||
XDOC PKG_XPATH.TDOCUMENT; -- Документ XML
|
||||
XROOT PKG_XPATH.TNODE; -- Корень документа XML
|
||||
XNODE PKG_XPATH.TNODE; -- Буфер узла документа
|
||||
begin
|
||||
/* Инициализируем результат */
|
||||
ROPT.RARGS := TARGS();
|
||||
/* Если данные есть */
|
||||
if (CXML is not null) then
|
||||
begin
|
||||
/* Разбираем XML */
|
||||
XDOC := PKG_XPATH.PARSE_FROM_CLOB(LCXML => CXML);
|
||||
/* Считываем корневой узел */
|
||||
XROOT := PKG_XPATH.ROOT_NODE(RDOCUMENT => XDOC);
|
||||
/* Считываем узел настройки */
|
||||
XNODE := PKG_XPATH.SINGLE_NODE(RPARENT_NODE => XROOT, SPATTERN => '/' || STAG_OPT);
|
||||
/* Десериализуем его */
|
||||
ROPT := TOPT_FROM_XML(CXML => PKG_XPATH.SERIALIZE_TO_CLOB(RNODE => XNODE));
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
exception
|
||||
when others then
|
||||
/* Освободим документ */
|
||||
PKG_XPATH.FREE(RDOCUMENT => XDOC);
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end;
|
||||
end if;
|
||||
/* Вернём сформированное */
|
||||
return ROPT;
|
||||
end QUERY_OPT_FROM_XML;
|
||||
|
||||
/* Сериализация запроса */
|
||||
function QUERY_TO_XML
|
||||
(
|
||||
@ -1518,9 +1954,9 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
PKG_XFAST.PROLOGUE(ITYPE => PKG_XFAST.CONTENT_, BALINE => true, BINDENT => true);
|
||||
/* Открываем корень */
|
||||
PKG_XFAST.DOWN_NODE(SNAME => STAG_DATA);
|
||||
/* Параметры */
|
||||
if (RQ.OPTS is not null) then
|
||||
null;
|
||||
/* Настройка */
|
||||
if (RQ.OPT is not null) then
|
||||
TOPT_TO_XML(ROPT => QUERY_OPT_FROM_XML(CXML => RQ.OPT));
|
||||
end if;
|
||||
/* Сущности (можно использовать просто PKG_XFAST.VALUE_XML и сразу отдать готовый XML из RQ.ENTS, но это приводит к формированию некорректного документа с лишней ">" между группами) */
|
||||
if (RQ.ENTS is not null) then
|
||||
@ -1547,8 +1983,19 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end QUERY_TO_XML;
|
||||
|
||||
/* Формирование описания запроса */
|
||||
function QUERY
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
) return clob -- XML-описание
|
||||
is
|
||||
begin
|
||||
/* Сериализуем запрос */
|
||||
return QUERY_TO_XML(NRN => NRN);
|
||||
end QUERY;
|
||||
|
||||
/* Формирование списка запросов */
|
||||
function QUERY_LIST_GET
|
||||
function QUERY_LIST
|
||||
(
|
||||
SUSER in varchar2 -- Имя пользователя
|
||||
) return clob -- Список запросов
|
||||
@ -1607,18 +2054,66 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
/* Вернем ошибку */
|
||||
PKG_STATE.DIAGNOSTICS_STACKED();
|
||||
P_EXCEPTION(0, PKG_STATE.SQL_ERRM());
|
||||
end QUERY_LIST_GET;
|
||||
end QUERY_LIST;
|
||||
|
||||
/* Получение описания запроса */
|
||||
function QUERY_DESC_GET
|
||||
/* Добавление запроса */
|
||||
procedure QUERY_INSERT
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
) return clob -- XML-описание
|
||||
SCODE in varchar2, -- Мнемокод
|
||||
SNAME in varchar2, -- Наименование
|
||||
NRN out number -- Рег. номер добавленного запроса
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Сериализуем запрос */
|
||||
return QUERY_TO_XML(NRN => NRN);
|
||||
end QUERY_DESC_GET;
|
||||
/* Проверим параметры */
|
||||
QUERY_CHECK(SCODE => SCODE, SNAME => SNAME);
|
||||
/* Формируем рег. номер */
|
||||
NRN := GEN_ID();
|
||||
/* Добавляем данные */
|
||||
insert into P8PNL_QE_QUERY
|
||||
(RN, CODE, name, AUTHOR, CH_DATE, READY, PBL)
|
||||
values
|
||||
(NRN, SCODE, SNAME, UTILIZER(), sysdate, 0, 0);
|
||||
end QUERY_INSERT;
|
||||
|
||||
/* Исправление запроса */
|
||||
procedure QUERY_UPDATE
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
SCODE in varchar2, -- Мнемокод
|
||||
SNAME in varchar2 -- Наименование
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Проверим параметры */
|
||||
QUERY_CHECK(SCODE => SCODE, SNAME => SNAME);
|
||||
/* Изменяем данные */
|
||||
update P8PNL_QE_QUERY T
|
||||
set T.CODE = SCODE,
|
||||
T.NAME = SNAME
|
||||
where T.RN = NRN;
|
||||
/* Контроль изменения данных */
|
||||
if (sql%notfound) then
|
||||
PKG_MSG.RECORD_NOT_FOUND(NDOCUMENT => NRN, SUNIT_TABLE => 'P8PNL_QE_QUERY');
|
||||
end if;
|
||||
/* Обновим дату изменения запроса */
|
||||
QUERY_CH_DATE_SYNC(NRN => NRN);
|
||||
end QUERY_UPDATE;
|
||||
|
||||
/* Удаление запроса */
|
||||
procedure QUERY_DELETE
|
||||
(
|
||||
NRN in number -- Рег. номер запроса
|
||||
)
|
||||
is
|
||||
begin
|
||||
/* Удаляем запись */
|
||||
delete from P8PNL_QE_QUERY T where T.RN = NRN;
|
||||
/* Контроль изменения данных */
|
||||
if (sql%notfound) then
|
||||
PKG_MSG.RECORD_NOT_FOUND(NDOCUMENT => NRN, SUNIT_TABLE => 'P8PNL_QE_QUERY');
|
||||
end if;
|
||||
end QUERY_DELETE;
|
||||
|
||||
/* Чтение сущностей запроса */
|
||||
function QUERY_ENTS_GET
|
||||
@ -1787,5 +2282,37 @@ create or replace package body PKG_P8PANELS_QE_BASE as
|
||||
QUERY_CH_DATE_SYNC(NRN => NRN);
|
||||
end QUERY_PBL_SET;
|
||||
|
||||
/* Чтение настройки запроса */
|
||||
function QUERY_OPT_GET
|
||||
(
|
||||
COPT in clob -- Сериализованное описание настройки запроса
|
||||
) return TOPT -- Настройка запроса
|
||||
is
|
||||
begin
|
||||
/* Десериализуем */
|
||||
return QUERY_OPT_FROM_XML(CXML => COPT);
|
||||
end QUERY_OPT_GET;
|
||||
|
||||
/* Запись настройки запроса */
|
||||
procedure QUERY_OPT_SET
|
||||
(
|
||||
NRN in number, -- Рег. номер запроса
|
||||
ROPT in TOPT -- Настройка запроса
|
||||
)
|
||||
is
|
||||
COPT clob; -- Буфер для сериализации
|
||||
begin
|
||||
/* Сериализуем настройку */
|
||||
COPT := QUERY_OPT_TO_XML(ROPT => ROPT);
|
||||
/* Сохраним её */
|
||||
update P8PNL_QE_QUERY T set T.OPT = COPT where T.RN = NRN;
|
||||
/* Контроль изменения данных */
|
||||
if (sql%notfound) then
|
||||
PKG_MSG.RECORD_NOT_FOUND(NDOCUMENT => NRN, SUNIT_TABLE => 'P8PNL_QE_QUERY');
|
||||
end if;
|
||||
/* Обновим дату изменения запроса */
|
||||
QUERY_CH_DATE_SYNC(NRN => NRN);
|
||||
end QUERY_OPT_SET;
|
||||
|
||||
end PKG_P8PANELS_QE_BASE;
|
||||
/
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user