The following lines contain the word 'select', 'insert', 'update' or 'delete':
| that they were inserted by datamerge. |
| |
| The ADD_ROW routine will see whether a row exists by selecting |
| based on the primary key, and updates the row if it exists, |
| or inserts the row if it doesn't already exist. |
| |
| This module is called by AutoInstall (afplss.drv) on install and |
| upgrade. The WHENEVER SQLERROR and EXIT (at bottom) are required. |
| |
| HISTORY |
| who when what |
| veramach July 2004 FA 151 HR Integration |
| Obsoleted ld_cal_type,ld_sequence_number, |
| hrs_worked |
| Added check_constraints |
| brajendr 01-Jul-2002 Bug # 2415194 |
| Modified the Message IGF_SE_ERR_PAY_ADJ to |
| have the extra token to give more clarity |
| |
*=======================================================================*/
l_rowid VARCHAR2(25);
x_last_update_date IN DATE ,
x_last_updated_by IN NUMBER ,
x_last_update_login IN NUMBER
) AS
/*
|| Created By : ssawhney
|| Created On : 31-DEC-2001
|| Purpose : Initialises the Old and New references for the columns of the table.
|| Known limitations, enhancements or remarks :
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
CURSOR cur_old_ref_values IS
SELECT *
FROM IGF_SE_PAYMENT
WHERE rowid = x_rowid;
IF ((cur_old_ref_values%NOTFOUND) AND (p_action NOT IN ('INSERT', 'VALIDATE_INSERT'))) THEN
CLOSE cur_old_ref_values;
fnd_message.set_name ('FND', 'FORM_RECORD_DELETED');
IF (p_action = 'UPDATE') THEN
new_references.creation_date := old_references.creation_date;
new_references.last_update_date := x_last_update_date;
new_references.last_updated_by := x_last_updated_by;
new_references.last_update_login := x_last_update_login;
fnd_message.set_name ('FND', 'FORM_RECORD_DELETED');
SELECT rowid
FROM igf_se_payment
WHERE transaction_id = x_transaction_id
FOR UPDATE NOWAIT;
SELECT rowid
FROM igf_se_payment
WHERE ((person_id = x_party_id));
SELECT 'x'
FROM igf_se_auth
WHERE auth_id = cp_auth_id
AND person_id = cp_person_id
AND flag = 'A';
SELECT auth.fund_id
FROM igf_se_auth auth
WHERE auth_id = cp_auth_id
AND person_id = cp_person_id;
SELECT 'x'
FROM igf_lookups_view
WHERE lookup_type = cp_lookup_type
AND lookup_code = cp_lookup_code
AND enabled_flag = 'Y';
SELECT party_number
FROM hz_parties
WHERE party_id = cp_person_id;
x_last_update_date IN DATE ,
x_last_updated_by IN NUMBER ,
x_last_update_login IN NUMBER
) AS
/*
|| Created By : ssawhney
|| Created On : 31-DEC-2001
|| Purpose : Initialises the columns, Checks Constraints, Calls the
|| Trigger Handlers for the table, before any DML operation.
|| Known limitations, enhancements or remarks :
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
BEGIN
set_column_values (
p_action,
x_rowid,
x_transaction_id,
x_payroll_id,
x_payroll_date,
x_auth_id,
x_person_id,
x_fund_id,
x_paid_amount,
x_org_unit_cd,
x_source,
x_creation_date,
x_created_by,
x_last_update_date,
x_last_updated_by,
x_last_update_login
);
IF (p_action = 'INSERT') THEN
-- Call all the procedures related to Before Insert.
IF ( get_pk_for_validation(
new_references.transaction_id
)
) THEN
fnd_message.set_name('IGS','IGS_GE_RECORD_ALREADY_EXISTS');
ELSIF (p_action = 'UPDATE') THEN
-- Call all the procedures related to Before Update.
check_parent_existance;
ELSIF (p_action = 'VALIDATE_INSERT') THEN
-- Call all the procedures related to Before Insert.
IF ( get_pk_for_validation (
new_references.transaction_id
)
) THEN
fnd_message.set_name('IGS','IGS_GE_RECORD_ALREADY_EXISTS');
PROCEDURE insert_row (
x_rowid IN OUT NOCOPY VARCHAR2,
x_transaction_id IN OUT NOCOPY NUMBER,
x_payroll_id IN NUMBER,
x_payroll_date IN DATE,
x_auth_id IN NUMBER,
x_person_id IN NUMBER,
x_fund_id IN NUMBER,
x_paid_amount IN NUMBER,
x_org_unit_cd IN VARCHAR2,
x_source IN VARCHAR2,
x_mode IN VARCHAR2
) AS
/*
|| Created By : ssawhney
|| Created On : 31-DEC-2001
|| Purpose : Handles the INSERT DML logic for the table.
|| Known limitations, enhancements or remarks :
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
CURSOR c IS
SELECT rowid
FROM igf_se_payment
WHERE transaction_id = x_transaction_id;
SELECT rowid , spi.*
FROM igf_se_payment_int spi
WHERE spi.auth_id =x_auth_id AND
spi.payroll_id =x_payroll_id AND
spi.status NOT IN ('DONE','ERROR');
SELECT meaning
FROM igf_lookups_view
WHERE lookup_type = 'IGF_STUD_EMP_ERROR'
AND lookup_code = c_error_cd;
x_last_update_date DATE;
x_last_updated_by NUMBER;
x_last_update_login NUMBER;
x_program_update_date DATE;
x_last_update_date := SYSDATE;
x_last_updated_by := 1;
x_last_update_login := 0;
x_last_updated_by := fnd_global.user_id;
IF (x_last_updated_by IS NULL) THEN
x_last_updated_by := -1;
x_last_update_login := fnd_global.login_id;
IF (x_last_update_login IS NULL) THEN
x_last_update_login := -1;
x_program_update_date := NULL;
x_program_update_date := SYSDATE;
SELECT igf_se_payment_s.NEXTVAL
INTO x_transaction_id
FROM dual;
p_action => 'INSERT',
x_rowid => x_rowid,
x_transaction_id => x_transaction_id,
x_payroll_id => x_payroll_id,
x_payroll_date => x_payroll_date,
x_auth_id => x_auth_id,
x_person_id => x_person_id,
x_fund_id => x_fund_id,
x_paid_amount => x_paid_amount,
x_org_unit_cd => x_org_unit_cd,
x_source => x_source,
x_creation_date => x_last_update_date,
x_created_by => x_last_updated_by,
x_last_update_date => x_last_update_date,
x_last_updated_by => x_last_updated_by,
x_last_update_login => x_last_update_login
);
INSERT INTO igf_se_payment (
transaction_id,
payroll_id,
payroll_date,
auth_id,
person_id,
fund_id,
paid_amount,
org_unit_cd,
source,
creation_date,
created_by,
last_update_date,
last_updated_by,
last_update_login,
request_id,
program_id,
program_application_id,
program_update_date
) VALUES (
new_references.transaction_id,
new_references.payroll_id,
new_references.payroll_date,
new_references.auth_id,
new_references.person_id,
new_references.fund_id,
new_references.paid_amount,
new_references.org_unit_cd,
new_references.source,
x_last_update_date,
x_last_updated_by,
x_last_update_date,
x_last_updated_by,
x_last_update_login ,
x_request_id,
x_program_id,
x_program_application_id,
x_program_update_date
);
igf_se_payment_int_pkg.update_row (
x_rowid => payment_int_rec.rowid,
x_transaction_id => payment_int_rec.transaction_id,
x_batch_id => payment_int_rec.batch_id,
x_payroll_id => payment_int_rec.payroll_id,
x_payroll_date => payment_int_rec.payroll_date,
x_auth_id => payment_int_rec.auth_id,
x_person_id => payment_int_rec.person_id,
x_fund_id => payment_int_rec.fund_id,
x_paid_amount => payment_int_rec.paid_amount,
x_org_unit_cd => payment_int_rec.org_unit_cd,
x_status => l_status,
x_error_code => l_error
);
igf_se_payment_int_pkg.update_row (
x_rowid => payment_int_rec.rowid,
x_transaction_id => payment_int_rec.transaction_id,
x_batch_id => payment_int_rec.batch_id,
x_payroll_id => payment_int_rec.payroll_id,
x_payroll_date => payment_int_rec.payroll_date,
x_auth_id => payment_int_rec.auth_id,
x_person_id => payment_int_rec.person_id,
x_fund_id => payment_int_rec.fund_id,
x_paid_amount => payment_int_rec.paid_amount,
x_org_unit_cd => payment_int_rec.org_unit_cd,
x_status => l_status,
x_error_code => l_error
);
END insert_row;
SELECT
payroll_id,
payroll_date,
auth_id,
person_id,
fund_id,
paid_amount,
org_unit_cd,
source
FROM igf_se_payment
WHERE rowid = x_rowid
FOR UPDATE NOWAIT;
fnd_message.set_name('FND', 'FORM_RECORD_DELETED');
PROCEDURE update_row (
x_rowid IN VARCHAR2,
x_transaction_id IN NUMBER,
x_payroll_id IN NUMBER,
x_payroll_date IN DATE,
x_auth_id IN NUMBER,
x_person_id IN NUMBER,
x_fund_id IN NUMBER,
x_paid_amount IN NUMBER,
x_org_unit_cd IN VARCHAR2,
x_source IN VARCHAR2,
x_mode IN VARCHAR2
) AS
/*
|| Created By : ssawhney
|| Created On : 31-DEC-2001
|| Purpose : Handles the UPDATE DML logic for the table.
|| Known limitations, enhancements or remarks :
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
CURSOR c_get_se_errors(
c_error_cd igf_se_payment_int.error_code%TYPE
) IS
SELECT meaning
FROM igf_lookups_view
WHERE lookup_type = 'IGF_STUD_EMP_ERROR'
AND lookup_code = c_error_cd;
x_last_update_date DATE ;
x_last_updated_by NUMBER;
x_last_update_login NUMBER;
x_program_update_date DATE;
SELECT rowid , spi.*
FROM igf_se_payment_int spi
WHERE spi.auth_id =x_auth_id AND
spi.payroll_id =x_payroll_id AND
spi.status NOT IN ('DONE','ERROR');
x_last_update_date := SYSDATE;
x_last_updated_by := 1;
x_last_update_login := 0;
x_last_updated_by := fnd_global.user_id;
IF x_last_updated_by IS NULL THEN
x_last_updated_by := -1;
x_last_update_login := fnd_global.login_id;
IF (x_last_update_login IS NULL) THEN
x_last_update_login := -1;
p_action => 'UPDATE',
x_rowid => x_rowid,
x_transaction_id => x_transaction_id,
x_payroll_id => x_payroll_id,
x_payroll_date => x_payroll_date,
x_auth_id => x_auth_id,
x_person_id => x_person_id,
x_fund_id => x_fund_id,
x_paid_amount => x_paid_amount,
x_org_unit_cd => x_org_unit_cd,
x_source => x_source,
x_creation_date => x_last_update_date,
x_created_by => x_last_updated_by,
x_last_update_date => x_last_update_date,
x_last_updated_by => x_last_updated_by,
x_last_update_login => x_last_update_login
);
x_program_update_date := old_references.program_update_date;
x_program_update_date := SYSDATE;
UPDATE igf_se_payment
SET
payroll_id = new_references.payroll_id,
payroll_date = new_references.payroll_date,
auth_id = new_references.auth_id,
person_id = new_references.person_id,
fund_id = new_references.fund_id,
paid_amount = new_references.paid_amount,
org_unit_cd = new_references.org_unit_cd,
source = new_references.source,
last_update_date = x_last_update_date,
last_updated_by = x_last_updated_by,
last_update_login = x_last_update_login ,
request_id = x_request_id,
program_id = x_program_id,
program_application_id = x_program_application_id,
program_update_date = x_program_update_date
WHERE rowid = x_rowid;
igf_se_payment_int_pkg.update_row(
x_rowid => payment_int_rec.rowid,
x_transaction_id => payment_int_rec.transaction_id,
x_batch_id => payment_int_rec.batch_id,
x_payroll_id => payment_int_rec.payroll_id,
x_payroll_date => payment_int_rec.payroll_date,
x_auth_id => payment_int_rec.auth_id,
x_person_id => payment_int_rec.person_id,
x_fund_id => payment_int_rec.fund_id,
x_paid_amount => payment_int_rec.paid_amount,
x_org_unit_cd => payment_int_rec.org_unit_cd,
x_status => l_status,
x_error_code => l_error
);
igf_se_payment_int_pkg.update_row(
x_rowid => payment_int_rec.rowid,
x_transaction_id => payment_int_rec.transaction_id,
x_batch_id => payment_int_rec.batch_id,
x_payroll_id => payment_int_rec.payroll_id,
x_payroll_date => payment_int_rec.payroll_date,
x_auth_id => payment_int_rec.auth_id,
x_person_id => payment_int_rec.person_id,
x_fund_id => payment_int_rec.fund_id,
x_paid_amount => payment_int_rec.paid_amount,
x_org_unit_cd => payment_int_rec.org_unit_cd,
x_status => l_status,
x_error_code => l_error
);
END update_row;
|| Purpose : Adds a row if there is no existing row, otherwise updates existing row in the table.
|| Known limitations, enhancements or remarks : AVOID USING THIS. DUE TO SPECIFIC LOGIC OF INSERT/UPDATE
|| FOR THIS TABLE.
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
CURSOR c1 IS
SELECT rowid
FROM igf_se_payment
WHERE transaction_id = x_transaction_id;
insert_row (
x_rowid,
x_transaction_id,
x_payroll_id,
x_payroll_date,
x_auth_id,
x_person_id,
x_fund_id,
x_paid_amount,
x_org_unit_cd,
x_source,
x_mode
);
update_row (
x_rowid,
x_transaction_id,
x_payroll_id,
x_payroll_date,
x_auth_id,
x_person_id,
x_fund_id,
x_paid_amount,
x_org_unit_cd,
x_source,
x_mode
);
PROCEDURE delete_row (
x_rowid IN VARCHAR2
) AS
/*
|| Created By : ssawhney
|| Created On : 31-DEC-2001
|| Purpose : Handles the DELETE DML logic for the table.
|| Known limitations, enhancements or remarks :
|| Change History :
|| Who When What
|| (reverse chronological order - newest change first)
*/
BEGIN
before_dml (
p_action => 'DELETE',
x_rowid => x_rowid
);
DELETE FROM igf_se_payment
WHERE rowid = x_rowid;
END delete_row;