45 lines
1.8 KiB
Plaintext
45 lines
1.8 KiB
Plaintext
CREATE OR REPLACE TRIGGER "EFT_NOM".cg$ADS_OPTION_PACKAGES
|
|
|
|
AFTER DELETE ON OPTION_PACKAGES
|
|
|
|
|
|
DECLARE
|
|
idx BINARY_INTEGER := cg$OPTION_PACKAGES.cg$table.FIRST;
|
|
cg$rec cg$OPTION_PACKAGES.cg$row_type;
|
|
cg$old_rec cg$OPTION_PACKAGES.cg$row_type;
|
|
BEGIN
|
|
-- Application_logic Pre-After-Delete-statement <<Start>>
|
|
-- Application_logic Pre-After-Delete-statement << End >>
|
|
|
|
IF NOT (cg$OPTION_PACKAGES.called_from_package) THEN
|
|
WHILE idx IS NOT NULL LOOP
|
|
cg$rec.OPPA_ID := cg$OPTION_PACKAGES.cg$table(idx).OPPA_ID;
|
|
cg$OPTION_PACKAGES.cg$tableind(idx).OPPA_ID := TRUE;
|
|
cg$rec.SYOP_SYOP_ID := cg$OPTION_PACKAGES.cg$table(idx).SYOP_SYOP_ID;
|
|
cg$OPTION_PACKAGES.cg$tableind(idx).SYOP_SYOP_ID := TRUE;
|
|
cg$rec.PACKAGE_NAME := cg$OPTION_PACKAGES.cg$table(idx).PACKAGE_NAME;
|
|
cg$OPTION_PACKAGES.cg$tableind(idx).PACKAGE_NAME := TRUE;
|
|
cg$rec.ENTRY_POINT := cg$OPTION_PACKAGES.cg$table(idx).ENTRY_POINT;
|
|
cg$OPTION_PACKAGES.cg$tableind(idx).ENTRY_POINT := TRUE;
|
|
|
|
cg$OPTION_PACKAGES.validate_foreign_keys_del(cg$rec);
|
|
cg$OPTION_PACKAGES.upd_oper_denorm2( cg$rec,
|
|
cg$old_rec,
|
|
cg$OPTION_PACKAGES.cg$tableind(idx),
|
|
'DEL'
|
|
);
|
|
|
|
cg$OPTION_PACKAGES.cascade_delete(cg$rec);
|
|
cg$OPTION_PACKAGES.domain_cascade_delete(cg$rec);
|
|
|
|
idx := cg$OPTION_PACKAGES.cg$table.NEXT(idx);
|
|
END LOOP;
|
|
END IF;
|
|
|
|
-- Application_logic Post-After-Delete-statement <<Start>>
|
|
-- Application_logic Post-After-Delete-statement << End >>
|
|
|
|
END;
|
|
/
|
|
|