KEY-DUPREC
---------------------------------------------------------------------------------------------------------------
APP_STANDARD.EVENT('KEY-DUPREC');
This trigger disables the default duplicate record functionality of Oracle Forms.
To process the "Edit, Duplicate Record Above" menu choice properly,
code a block-level KEY-DUPREC with execution style 'Override'.
This trigger should perform a duplicate_record, then validate or clear fields as needed.
Why Duplicate Record is Disabled by Default
----------------------------------------------------------------------------------------------------------------
By default, duplicate record is disabled at the form level. There are several reasons for this:
The special column ROW_ID is duplicated and must be manually exempted if it exists
The record is marked as valid even through the items may contain time-sensitive data that is no longer valid
Defaults are overridden
In many blocks, Duplicate Record makes no sense (modal dialogs, find blocks, etc.)
For any block where you want to enable Duplicate Record, you must write code. You must process unique keys,
possibly reapply defaults, and confirm that copied data is still valid.
None of this is done by default, and this can lead to errors or data corruption.
In general, duplicate all item values, even if the item value must be unique.
The user may wish to create a unique value very similar to the previous value.
Do not override a default if
The item cannot be modified by the user
The item must contain a specific value for a new record
The item is a sequential number and the default is the correct value most of the time
Example
------------------
A block order has items order_number and order_date which are defaulted from the sequence order_S and from SYSDATE respectively,
and which cannot be modified by the user.
The item status should contain "Open" for a new order,
but the user can change the Status to "Book" at any time to book the order.
Create your event handler procedures as follows:
PACKAGE BODY order IS
PROCEDURE KEY_DUPREC IS
CURSOR new_order_number IS SELECT order_S.nextval
FROM sys.dual;
BEGIN
DUPLICATE_RECORD;
open new_order_number;
fetch new_order_number into :order.order_number;
close new_order_number;
:order.status : = 'Open';
:order.order_date := FND_STANDARD.SYSTEM_DATE;
:order.row_id := null;
END KEY_DUPREC;
END order;
Call your event handler procedures in:
Trigger: KEY-DUPREC on order:
order.KEY_DUPREC;
---------------------------------------------------------------------------------------------------------------
APP_STANDARD.EVENT('KEY-DUPREC');
This trigger disables the default duplicate record functionality of Oracle Forms.
To process the "Edit, Duplicate Record Above" menu choice properly,
code a block-level KEY-DUPREC with execution style 'Override'.
This trigger should perform a duplicate_record, then validate or clear fields as needed.
Why Duplicate Record is Disabled by Default
----------------------------------------------------------------------------------------------------------------
By default, duplicate record is disabled at the form level. There are several reasons for this:
The special column ROW_ID is duplicated and must be manually exempted if it exists
The record is marked as valid even through the items may contain time-sensitive data that is no longer valid
Defaults are overridden
In many blocks, Duplicate Record makes no sense (modal dialogs, find blocks, etc.)
For any block where you want to enable Duplicate Record, you must write code. You must process unique keys,
possibly reapply defaults, and confirm that copied data is still valid.
None of this is done by default, and this can lead to errors or data corruption.
In general, duplicate all item values, even if the item value must be unique.
The user may wish to create a unique value very similar to the previous value.
Do not override a default if
The item cannot be modified by the user
The item must contain a specific value for a new record
The item is a sequential number and the default is the correct value most of the time
Example
------------------
A block order has items order_number and order_date which are defaulted from the sequence order_S and from SYSDATE respectively,
and which cannot be modified by the user.
The item status should contain "Open" for a new order,
but the user can change the Status to "Book" at any time to book the order.
Create your event handler procedures as follows:
PACKAGE BODY order IS
PROCEDURE KEY_DUPREC IS
CURSOR new_order_number IS SELECT order_S.nextval
FROM sys.dual;
BEGIN
DUPLICATE_RECORD;
open new_order_number;
fetch new_order_number into :order.order_number;
close new_order_number;
:order.status : = 'Open';
:order.order_date := FND_STANDARD.SYSTEM_DATE;
:order.row_id := null;
END KEY_DUPREC;
END order;
Call your event handler procedures in:
Trigger: KEY-DUPREC on order:
order.KEY_DUPREC;