The following lines contain the word 'select', 'insert', 'update' or 'delete':
x_last_update_date IN DATE ,
x_last_updated_by IN NUMBER ,
x_last_update_login IN NUMBER ,
x_org_id IN NUMBER ,
x_program_length IN NUMBER ,
x_program_length_measurement IN VARCHAR2
) AS
CURSOR cur_old_ref_values IS
SELECT *
FROM IGS_PS_OFR_OPT_ALL
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;
PROCEDURE BeforeRowInsertUpdateDelete1(
p_inserting IN BOOLEAN ,
p_updating IN BOOLEAN ,
p_deleting IN BOOLEAN
) AS
v_message_name VARCHAR2(30);
IF p_inserting OR p_updating THEN
v_course_cd := new_references.course_cd;
-- Validate that updates are allowed
IF IGS_PS_VAL_CRS.CRSP_VAL_IUD_CRV_DTL(v_course_cd,
v_version_number,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS',v_message_name);
IF p_inserting THEN
-- Validate calendar type
IF IGS_PS_VAL_CO.crsp_val_co_cal_type(
new_references.cal_type,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS',v_message_name);
IF p_inserting OR p_updating THEN
IF new_references.enr_officer_person_id IS NOT NULL THEN
-- Validate enrolment officer IGS_PE_PERSON id
IF IGS_GE_MNT_SDTT.PID_VAL_STAFF (
new_references.enr_officer_person_id,
v_preferred_name) = FALSE THEN
Fnd_Message.Set_Name('IGS','IGS_GE_NOT_STAFF_MEMBER');
END BeforeRowInsertUpdateDelete1; -- updated by ssawhney on 09/08/2k for TCA changes
Fnd_Message.Set_Name ('FND', 'FORM_RECORD_DELETED');
Fnd_Message.Set_Name ('FND', 'FORM_RECORD_DELETED');
Fnd_Message.Set_Name ('FND', 'FORM_RECORD_DELETED');
Fnd_Message.Set_Name ('FND', 'FORM_RECORD_DELETED');
Fnd_Message.Set_Name ('FND', 'FORM_RECORD_DELETED');
SELECT '1' FROM USER_OBJECTS
WHERE OBJECT_NAME = 'IGS_HE_POOUS_ALL_PKG'
AND object_type = 'PACKAGE BODY';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE course_cd = x_course_cd
AND version_number = x_version_number
AND cal_type = x_cal_type
AND location_cd = x_location_cd
AND attendance_mode = x_attendance_mode
AND attendance_type = x_attendance_type
AND DELETE_FLAG = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE coo_id = x_coo_id
AND ((l_rowid IS NULL) OR (rowid <> l_rowid))
AND DELETE_FLAG = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE attendance_mode = x_attendance_mode
AND delete_flag = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE attendance_type = x_attendance_type
AND delete_flag = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE course_cd = x_course_cd
AND version_number = x_version_number
AND cal_type = x_cal_type
AND delete_flag = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE location_cd = x_location_cd
AND delete_flag = 'N';
SELECT rowid
FROM IGS_PS_OFR_OPT_ALL
WHERE enr_officer_person_id = x_person_id
AND delete_flag = 'N';
x_last_update_date IN DATE ,
x_last_updated_by IN NUMBER ,
x_last_update_login IN NUMBER ,
x_org_id IN NUMBER ,
x_program_length IN NUMBER ,
x_program_length_measurement IN VARCHAR2 ,
X_DELETE_FLAG IN VARCHAR2
) AS
BEGIN
Set_Column_Values (
p_action,
x_rowid,
x_course_cd,
x_version_number,
x_cal_type,
x_location_cd,
x_attendance_mode,
x_attendance_type,
x_coo_id,
x_forced_location_ind,
x_forced_att_mode_ind,
x_forced_att_type_ind,
x_time_limitation,
x_enr_officer_person_id,
x_attribute_category,
x_attribute1,
x_attribute2,
x_attribute3,
x_attribute4,
x_attribute5,
x_attribute6,
x_attribute7,
x_attribute8,
x_attribute9,
x_attribute10,
x_attribute11,
x_attribute12,
x_attribute13,
x_attribute14,
x_attribute15,
x_attribute16,
x_attribute17,
x_attribute18,
x_attribute19,
x_attribute20,
x_creation_date,
x_created_by,
x_last_update_date,
x_last_updated_by,
x_last_update_login ,
x_org_id,
x_program_length,
x_program_length_measurement
);
IF (p_action = 'INSERT') THEN
-- Call all the procedures related to Before Insert.
BeforeRowInsertUpdateDelete1 ( p_inserting => TRUE , p_updating => FALSE, p_deleting => FALSE );
ELSIF (p_action = 'UPDATE') THEN
-- Call all the procedures related to Before Update.
BeforeRowInsertUpdateDelete1 ( p_updating => TRUE, p_inserting => FALSE, p_deleting=> FALSE );
ELSIF (p_action = 'DELETE') THEN
-- Call all the procedures related to Before Delete.
BeforeRowInsertUpdateDelete1 ( p_deleting => TRUE, p_updating => FALSE, p_inserting => FALSE );
ELSIF (p_action = 'VALIDATE_INSERT') THEN
IF Get_PK_For_Validation (
new_references.course_cd,
new_references.version_number,
new_references.cal_type,
new_references.location_cd,
new_references.attendance_mode,
new_references.attendance_type ) THEN
Fnd_Message.Set_Name ('IGS', 'IGS_GE_MULTI_ORG_DUP_REC');
ELSIF (p_action = 'VALIDATE_UPDATE') THEN
Check_Uniqueness;
ELSIF (p_action = 'VALIDATE_DELETE') THEN
Check_Child_Existance;
Purpose : Insertion into table IGS_PS_PT_REF_CD for mandatory ref code types and default ref codes
Known limitations, enhancements or remarks:
Change History :
Who When What
*************************************************************************/
CURSOR c_ofr_opt (cp_coo_id igs_ps_ofr_opt.coo_id%TYPE) IS
SELECT course_cd,
version_number,
cal_type,
location_cd,
attendance_type,
attendance_mode
FROM igs_ps_ofr_opt
WHERE coo_id = cp_coo_id;
SELECT reference_cd_type
FROM igs_ge_ref_cd_type_all
WHERE mandatory_flag ='Y'
AND program_offering_option_flag ='Y'
AND restricted_flag='Y'
AND closed_ind = 'N';
SELECT reference_cd,
description
FROM igs_ge_ref_cd
WHERE reference_cd_type = cp_reference_cd_type
AND default_flag = 'Y';
SELECT igs_ps_ent_pt_ref_cd_seq_num_s.NEXTVAL
FROM dual;
-- insert a value in igs_ps_ent_pt_ref_cd for every value of course_cd and version_number having
-- a applicable program offering option defined as mandatory and a default reference code
BEGIN
l_c_rowid:=NULL;
igs_ps_ent_pt_ref_cd_pkg.insert_row( x_rowid => l_c_rowid,
x_course_cd => l_ofr_opt.course_cd,
x_sequence_number => l_n_sequence_number,
x_reference_cd_type => cur_igs_ge_ref_cd_type_all.reference_cd_type,
x_attendance_type => l_ofr_opt.attendance_type,
x_cal_type => l_ofr_opt.cal_type,
x_location_cd => l_ofr_opt.location_cd,
x_version_number => l_ofr_opt.version_number,
x_attendance_mode => l_ofr_opt.attendance_mode,
x_coo_id => p_n_coo_id,
x_unit_set_cd => NULL,
x_us_version_number => NULL,
x_reference_cd => cur_igs_ge_ref_cd.reference_cd,
x_description => cur_igs_ge_ref_cd.description,
x_mode => 'R' );
-- The failure of insertion of reference code should not stop the creation of new program offering option.
-- Hence any exception raised by the TBH is trapped and the current processing is allowed to proceed.
WHEN OTHERS THEN
NULL;
SELECT coo_id
FROM igs_ps_ofr_opt
WHERE ROWID = cp_rowid;
IF ( p_action = 'INSERT') THEN
OPEN c_coo(x_rowid);
procedure INSERT_ROW (
X_ROWID in out NOCOPY VARCHAR2,
X_COURSE_CD in VARCHAR2,
X_VERSION_NUMBER in NUMBER,
X_CAL_TYPE in VARCHAR2,
X_ATTENDANCE_MODE in VARCHAR2,
X_ATTENDANCE_TYPE in VARCHAR2,
X_LOCATION_CD in VARCHAR2,
X_COO_ID in NUMBER,
X_FORCED_LOCATION_IND in VARCHAR2,
X_FORCED_ATT_MODE_IND in VARCHAR2,
X_FORCED_ATT_TYPE_IND in VARCHAR2,
X_TIME_LIMITATION in NUMBER,
X_ENR_OFFICER_PERSON_ID in NUMBER,
x_attribute_category in VARCHAR2 ,
x_attribute1 in VARCHAR2 ,
x_attribute2 in VARCHAR2 ,
x_attribute3 in VARCHAR2 ,
x_attribute4 in VARCHAR2 ,
x_attribute5 in VARCHAR2 ,
x_attribute6 in VARCHAR2 ,
x_attribute7 in VARCHAR2 ,
x_attribute8 in VARCHAR2 ,
x_attribute9 in VARCHAR2 ,
x_attribute10 in VARCHAR2 ,
x_attribute11 in VARCHAR2 ,
x_attribute12 in VARCHAR2 ,
x_attribute13 in VARCHAR2 ,
x_attribute14 in VARCHAR2 ,
x_attribute15 in VARCHAR2 ,
x_attribute16 in VARCHAR2 ,
x_attribute17 in VARCHAR2 ,
x_attribute18 in VARCHAR2 ,
x_attribute19 in VARCHAR2 ,
x_attribute20 in VARCHAR2 ,
X_MODE in VARCHAR2 ,
X_ORG_ID in NUMBER,
x_program_length IN NUMBER ,
x_program_length_measurement IN VARCHAR2 ,
X_DELETE_FLAG IN VARCHAR2
) AS
--This cursor is added as a part of locking build
CURSOR cur_check_for_deleted_rec(cp_course_cd igs_ps_ofr_opt_all.course_cd%TYPE,
cp_version_number igs_ps_ofr_opt_all.version_number%TYPE,
cp_cal_type igs_ps_ofr_opt_all.cal_type%TYPE,
cp_location_cd igs_ps_ofr_opt_all.location_cd%TYPE,
cp_attendance_mode igs_ps_ofr_opt_all.attendance_mode%TYPE,
cp_attendance_type igs_ps_ofr_opt_all.attendance_type%TYPE) IS
SELECT rowid
FROM igs_ps_ofr_opt_all
WHERE course_cd=cp_course_cd
AND version_number=cp_version_number
AND cal_type =cp_cal_type
AND location_cd = cp_location_cd
AND attendance_type= cp_attendance_type
AND attendance_mode = cp_attendance_mode
AND delete_flag = 'Y';
cursor C is select ROWID from IGS_PS_OFR_OPT_ALL
where COURSE_CD = X_COURSE_CD
and VERSION_NUMBER = X_VERSION_NUMBER
and CAL_TYPE = X_CAL_TYPE
and ATTENDANCE_MODE = X_ATTENDANCE_MODE
and ATTENDANCE_TYPE = X_ATTENDANCE_TYPE
and LOCATION_CD = X_LOCATION_CD;
X_LAST_UPDATE_DATE DATE;
X_LAST_UPDATED_BY NUMBER;
X_LAST_UPDATE_LOGIN NUMBER;
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 => 'INSERT',
x_rowid => X_ROWID,
x_course_cd => X_COURSE_CD,
x_version_number => X_VERSION_NUMBER,
x_cal_type => X_CAL_TYPE,
x_location_cd => X_LOCATION_CD,
x_attendance_mode => X_ATTENDANCE_MODE,
x_attendance_type => X_ATTENDANCE_TYPE,
x_coo_id => X_COO_ID,
x_forced_location_ind =>NVL(X_FORCED_LOCATION_IND,'N'),
x_forced_att_mode_ind => NVL(X_FORCED_ATT_MODE_IND,'N'),
x_forced_att_type_ind => NVL(X_FORCED_ATT_TYPE_IND,'N'),
x_time_limitation => X_TIME_LIMITATION ,
x_enr_officer_person_id => X_ENR_OFFICER_PERSON_ID ,
x_attribute_category => X_ATTRIBUTE_CATEGORY,
x_attribute1 => X_ATTRIBUTE1,
x_attribute2 => X_ATTRIBUTE2,
x_attribute3 => X_ATTRIBUTE3,
x_attribute4 => X_ATTRIBUTE4,
x_attribute5 => X_ATTRIBUTE5,
x_attribute6 => X_ATTRIBUTE6,
x_attribute7 => X_ATTRIBUTE7,
x_attribute8 => X_ATTRIBUTE8,
x_attribute9 => X_ATTRIBUTE9,
x_attribute10 => X_ATTRIBUTE10,
x_attribute11 => X_ATTRIBUTE11,
x_attribute12 => X_ATTRIBUTE12,
x_attribute13 => X_ATTRIBUTE13,
x_attribute14 => X_ATTRIBUTE14,
x_attribute15 => X_ATTRIBUTE15,
x_attribute16 => X_ATTRIBUTE16,
x_attribute17 => X_ATTRIBUTE17,
x_attribute18 => X_ATTRIBUTE18,
x_attribute19 => X_ATTRIBUTE19,
x_attribute20 => X_ATTRIBUTE20,
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_org_id => igs_ge_gen_003.get_org_id,
x_program_length => x_program_length,
x_program_length_measurement => x_program_length_measurement
);
OPEN cur_check_for_deleted_rec(x_course_cd,x_version_number,x_cal_type,x_location_cd,x_attendance_mode,
x_attendance_type);
FETCH cur_check_for_deleted_rec INTO l_rowid;
IF cur_check_for_deleted_rec%NOTFOUND THEN
CLOSE cur_check_for_deleted_rec;
insert into IGS_PS_OFR_OPT_ALL (
COURSE_CD,
VERSION_NUMBER,
CAL_TYPE,
LOCATION_CD,
ATTENDANCE_MODE,
ATTENDANCE_TYPE,
COO_ID,
FORCED_LOCATION_IND,
FORCED_ATT_MODE_IND,
FORCED_ATT_TYPE_IND,
TIME_LIMITATION,
ENR_OFFICER_PERSON_ID,
attribute_category,
attribute1,
attribute2,
attribute3,
attribute4,
attribute5,
attribute6,
attribute7,
attribute8,
attribute9,
attribute10,
attribute11,
attribute12,
attribute13,
attribute14,
attribute15,
attribute16,
attribute17,
attribute18,
attribute19,
attribute20,
CREATION_DATE,
CREATED_BY,
LAST_UPDATE_DATE,
LAST_UPDATED_BY,
LAST_UPDATE_LOGIN,
ORG_ID,
PROGRAM_LENGTH,
PROGRAM_LENGTH_MEASUREMENT,
DELETE_FLAG
) values (
NEW_REFERENCES.COURSE_CD,
NEW_REFERENCES.VERSION_NUMBER,
NEW_REFERENCES.CAL_TYPE,
NEW_REFERENCES.LOCATION_CD,
NEW_REFERENCES.ATTENDANCE_MODE,
NEW_REFERENCES.ATTENDANCE_TYPE,
NEW_REFERENCES.COO_ID,
NEW_REFERENCES.FORCED_LOCATION_IND,
NEW_REFERENCES.FORCED_ATT_MODE_IND,
NEW_REFERENCES.FORCED_ATT_TYPE_IND,
NEW_REFERENCES.TIME_LIMITATION,
NEW_REFERENCES.ENR_OFFICER_PERSON_ID,
NEW_REFERENCES.attribute_category,
NEW_REFERENCES.attribute1,
NEW_REFERENCES.attribute2,
NEW_REFERENCES.attribute3,
NEW_REFERENCES.attribute4,
NEW_REFERENCES.attribute5,
NEW_REFERENCES.attribute6,
NEW_REFERENCES.attribute7,
NEW_REFERENCES.attribute8,
NEW_REFERENCES.attribute9,
NEW_REFERENCES.attribute10,
NEW_REFERENCES.attribute11,
NEW_REFERENCES.attribute12,
NEW_REFERENCES.attribute13,
NEW_REFERENCES.attribute14,
NEW_REFERENCES.attribute15,
NEW_REFERENCES.attribute16,
NEW_REFERENCES.attribute17,
NEW_REFERENCES.attribute18,
NEW_REFERENCES.attribute19,
NEW_REFERENCES.attribute20,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_LOGIN,
NEW_REFERENCES.ORG_ID,
NEW_REFERENCES.PROGRAM_LENGTH,
NEW_REFERENCES.PROGRAM_LENGTH_MEASUREMENT,
'N'
);
CLOSE cur_check_for_deleted_rec;
UPDATE IGS_PS_OFR_OPT_ALL
SET
FORCED_LOCATION_IND=NEW_REFERENCES.FORCED_LOCATION_IND,
FORCED_ATT_MODE_IND=NEW_REFERENCES.FORCED_ATT_MODE_IND,
FORCED_ATT_TYPE_IND=NEW_REFERENCES.FORCED_ATT_TYPE_IND,
TIME_LIMITATION=NEW_REFERENCES.TIME_LIMITATION,
ENR_OFFICER_PERSON_ID=NEW_REFERENCES.ENR_OFFICER_PERSON_ID,
ATTRIBUTE_CATEGORY = NEW_REFERENCES.ATTRIBUTE_CATEGORY,
ATTRIBUTE1 = NEW_REFERENCES.ATTRIBUTE1,
ATTRIBUTE2 = NEW_REFERENCES.ATTRIBUTE2,
ATTRIBUTE3 = NEW_REFERENCES.ATTRIBUTE3,
ATTRIBUTE4 = NEW_REFERENCES.ATTRIBUTE4,
ATTRIBUTE5 = NEW_REFERENCES.ATTRIBUTE5,
ATTRIBUTE6 = NEW_REFERENCES.ATTRIBUTE6,
ATTRIBUTE7 = NEW_REFERENCES.ATTRIBUTE7,
ATTRIBUTE8 = NEW_REFERENCES.ATTRIBUTE8,
ATTRIBUTE9 = NEW_REFERENCES.ATTRIBUTE9,
ATTRIBUTE10 = NEW_REFERENCES.ATTRIBUTE10,
ATTRIBUTE11 = NEW_REFERENCES.ATTRIBUTE11,
ATTRIBUTE12 = NEW_REFERENCES.ATTRIBUTE12,
ATTRIBUTE13 = NEW_REFERENCES.ATTRIBUTE13,
ATTRIBUTE14 = NEW_REFERENCES.ATTRIBUTE14,
ATTRIBUTE15 = NEW_REFERENCES.ATTRIBUTE15,
ATTRIBUTE16 = NEW_REFERENCES.ATTRIBUTE16,
ATTRIBUTE17 = NEW_REFERENCES.ATTRIBUTE17,
ATTRIBUTE18 = NEW_REFERENCES.ATTRIBUTE18,
ATTRIBUTE19 = NEW_REFERENCES.ATTRIBUTE19,
ATTRIBUTE20 = NEW_REFERENCES.ATTRIBUTE20,
CREATION_DATE = X_LAST_UPDATE_DATE,
CREATED_BY = X_LAST_UPDATED_BY,
LAST_UPDATE_DATE = X_LAST_UPDATE_DATE,
LAST_UPDATED_BY = X_LAST_UPDATED_BY,
LAST_UPDATE_LOGIN = X_LAST_UPDATE_LOGIN,
ORG_ID = NEW_REFERENCES.ORG_ID,
PROGRAM_LENGTH = NEW_REFERENCES.PROGRAM_LENGTH,
PROGRAM_LENGTH_MEASUREMENT = NEW_REFERENCES.PROGRAM_LENGTH_MEASUREMENT,
DELETE_FLAG = 'N'
WHERE ROWID = l_rowid;
p_action => 'INSERT',
x_rowid => X_ROWID
);
p_action => 'UPDATE',
x_rowid => X_ROWID
);
end INSERT_ROW;
X_DELETE_FLAG IN VARCHAR2
) AS
cursor c1 is select
COO_ID,
FORCED_LOCATION_IND,
FORCED_ATT_MODE_IND,
FORCED_ATT_TYPE_IND,
TIME_LIMITATION,
ENR_OFFICER_PERSON_ID
from IGS_PS_OFR_OPT_ALL
where ROWID = X_ROWID
for update nowait;
fnd_message.set_name('FND', 'FORM_RECORD_DELETED');
procedure UPDATE_ROW (
X_ROWID IN VARCHAR2,
X_COURSE_CD in VARCHAR2,
X_VERSION_NUMBER in NUMBER,
X_CAL_TYPE in VARCHAR2,
X_ATTENDANCE_MODE in VARCHAR2,
X_ATTENDANCE_TYPE in VARCHAR2,
X_LOCATION_CD in VARCHAR2,
X_COO_ID in NUMBER,
X_FORCED_LOCATION_IND in VARCHAR2,
X_FORCED_ATT_MODE_IND in VARCHAR2,
X_FORCED_ATT_TYPE_IND in VARCHAR2,
X_TIME_LIMITATION in NUMBER,
X_ENR_OFFICER_PERSON_ID in NUMBER,
X_ATTRIBUTE_CATEGORY in VARCHAR2 ,
X_ATTRIBUTE1 in VARCHAR2 ,
X_ATTRIBUTE2 in VARCHAR2 ,
X_ATTRIBUTE3 in VARCHAR2 ,
X_ATTRIBUTE4 in VARCHAR2 ,
X_ATTRIBUTE5 in VARCHAR2 ,
X_ATTRIBUTE6 in VARCHAR2 ,
X_ATTRIBUTE7 in VARCHAR2 ,
X_ATTRIBUTE8 in VARCHAR2 ,
X_ATTRIBUTE9 in VARCHAR2 ,
X_ATTRIBUTE10 in VARCHAR2 ,
X_ATTRIBUTE11 in VARCHAR2 ,
X_ATTRIBUTE12 in VARCHAR2 ,
X_ATTRIBUTE13 in VARCHAR2 ,
X_ATTRIBUTE14 in VARCHAR2 ,
X_ATTRIBUTE15 in VARCHAR2 ,
X_ATTRIBUTE16 in VARCHAR2 ,
X_ATTRIBUTE17 in VARCHAR2 ,
X_ATTRIBUTE18 in VARCHAR2 ,
X_ATTRIBUTE19 in VARCHAR2 ,
X_ATTRIBUTE20 in VARCHAR2 ,
X_MODE in VARCHAR2,
x_program_length IN NUMBER ,
x_program_length_measurement IN VARCHAR2 ,
x_delete_flag IN VARCHAR2
) AS
X_LAST_UPDATE_DATE DATE;
X_LAST_UPDATED_BY NUMBER;
X_LAST_UPDATE_LOGIN NUMBER;
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_course_cd => X_COURSE_CD,
x_version_number => X_VERSION_NUMBER,
x_cal_type => X_CAL_TYPE,
x_location_cd => X_LOCATION_CD,
x_attendance_mode => X_ATTENDANCE_MODE,
x_attendance_type => X_ATTENDANCE_TYPE,
x_coo_id => X_COO_ID,
x_forced_location_ind => X_FORCED_LOCATION_IND ,
x_forced_att_mode_ind => X_FORCED_ATT_MODE_IND,
x_forced_att_type_ind => X_FORCED_ATT_TYPE_IND,
x_time_limitation => X_TIME_LIMITATION ,
x_enr_officer_person_id => X_ENR_OFFICER_PERSON_ID ,
x_attribute_category => X_ATTRIBUTE_CATEGORY,
x_attribute1 => X_ATTRIBUTE1,
x_attribute2 => X_ATTRIBUTE2,
x_attribute3 => X_ATTRIBUTE3,
x_attribute4 => X_ATTRIBUTE4,
x_attribute5 => X_ATTRIBUTE5,
x_attribute6 => X_ATTRIBUTE6,
x_attribute7 => X_ATTRIBUTE7,
x_attribute8 => X_ATTRIBUTE8,
x_attribute9 => X_ATTRIBUTE9,
x_attribute10 => X_ATTRIBUTE10,
x_attribute11 => X_ATTRIBUTE11,
x_attribute12 => X_ATTRIBUTE12,
x_attribute13 => X_ATTRIBUTE13,
x_attribute14 => X_ATTRIBUTE14,
x_attribute15 => X_ATTRIBUTE15,
x_attribute16 => X_ATTRIBUTE16,
x_attribute17 => X_ATTRIBUTE17,
x_attribute18 => X_ATTRIBUTE18,
x_attribute19 => X_ATTRIBUTE19,
x_attribute20 => X_ATTRIBUTE20,
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_length => X_program_length,
x_program_length_measurement => X_program_length_measurement
);
IF NVL(x_delete_flag,'N') = 'Y' THEN
Check_Child_Existance;
update IGS_PS_OFR_OPT_ALL set
COO_ID = NEW_REFERENCES.COO_ID,
FORCED_LOCATION_IND = NEW_REFERENCES.FORCED_LOCATION_IND,
FORCED_ATT_MODE_IND = NEW_REFERENCES.FORCED_ATT_MODE_IND,
FORCED_ATT_TYPE_IND = NEW_REFERENCES.FORCED_ATT_TYPE_IND,
TIME_LIMITATION = NEW_REFERENCES.TIME_LIMITATION,
ENR_OFFICER_PERSON_ID = NEW_REFERENCES.ENR_OFFICER_PERSON_ID,
ATTRIBUTE_CATEGORY = NEW_REFERENCES.ATTRIBUTE_CATEGORY,
ATTRIBUTE1 = NEW_REFERENCES.ATTRIBUTE1,
ATTRIBUTE2 = NEW_REFERENCES.ATTRIBUTE2,
ATTRIBUTE3 = NEW_REFERENCES.ATTRIBUTE3,
ATTRIBUTE4 = NEW_REFERENCES.ATTRIBUTE4,
ATTRIBUTE5 = NEW_REFERENCES.ATTRIBUTE5,
ATTRIBUTE6 = NEW_REFERENCES.ATTRIBUTE6,
ATTRIBUTE7 = NEW_REFERENCES.ATTRIBUTE7,
ATTRIBUTE8 = NEW_REFERENCES.ATTRIBUTE8,
ATTRIBUTE9 = NEW_REFERENCES.ATTRIBUTE9,
ATTRIBUTE10 = NEW_REFERENCES.ATTRIBUTE10,
ATTRIBUTE11 = NEW_REFERENCES.ATTRIBUTE11,
ATTRIBUTE12 = NEW_REFERENCES.ATTRIBUTE12,
ATTRIBUTE13 = NEW_REFERENCES.ATTRIBUTE13,
ATTRIBUTE14 = NEW_REFERENCES.ATTRIBUTE14,
ATTRIBUTE15 = NEW_REFERENCES.ATTRIBUTE15,
ATTRIBUTE16 = NEW_REFERENCES.ATTRIBUTE16,
ATTRIBUTE17 = NEW_REFERENCES.ATTRIBUTE17,
ATTRIBUTE18 = NEW_REFERENCES.ATTRIBUTE18,
ATTRIBUTE19 = NEW_REFERENCES.ATTRIBUTE19,
ATTRIBUTE20 = NEW_REFERENCES.ATTRIBUTE20,
LAST_UPDATE_DATE = X_LAST_UPDATE_DATE,
LAST_UPDATED_BY = X_LAST_UPDATED_BY,
LAST_UPDATE_LOGIN = X_LAST_UPDATE_LOGIN,
PROGRAM_LENGTH = NEW_REFERENCES.PROGRAM_LENGTH,
PROGRAM_LENGTH_MEASUREMENT = NEW_REFERENCES.PROGRAM_LENGTH_MEASUREMENT,
DELETE_FLAG = NVL(X_DELETE_FLAG,'N')
where ROWID = X_ROWID
;
p_action => 'UPDATE',
x_rowid => X_ROWID
);
end UPDATE_ROW;
X_DELETE_FLAG IN VARCHAR2
) AS
cursor c1 is select rowid from IGS_PS_OFR_OPT_ALL
where COURSE_CD = X_COURSE_CD
and VERSION_NUMBER = X_VERSION_NUMBER
and CAL_TYPE = X_CAL_TYPE
and ATTENDANCE_MODE = X_ATTENDANCE_MODE
and ATTENDANCE_TYPE = X_ATTENDANCE_TYPE
and LOCATION_CD = X_LOCATION_CD
;
INSERT_ROW (
X_ROWID,
X_COURSE_CD,
X_VERSION_NUMBER,
X_CAL_TYPE,
X_ATTENDANCE_MODE,
X_ATTENDANCE_TYPE,
X_LOCATION_CD,
X_COO_ID,
X_FORCED_LOCATION_IND,
X_FORCED_ATT_MODE_IND,
X_FORCED_ATT_TYPE_IND,
X_TIME_LIMITATION,
X_ENR_OFFICER_PERSON_ID,
X_ATTRIBUTE_CATEGORY,
X_ATTRIBUTE1,
X_ATTRIBUTE2,
X_ATTRIBUTE3,
X_ATTRIBUTE4,
X_ATTRIBUTE5,
X_ATTRIBUTE6,
X_ATTRIBUTE7,
X_ATTRIBUTE8,
X_ATTRIBUTE9,
X_ATTRIBUTE10,
X_ATTRIBUTE11,
X_ATTRIBUTE12,
X_ATTRIBUTE13,
X_ATTRIBUTE14,
X_ATTRIBUTE15,
X_ATTRIBUTE16,
X_ATTRIBUTE17,
X_ATTRIBUTE18,
X_ATTRIBUTE19,
X_ATTRIBUTE20,
X_MODE,
x_org_id,
X_PROGRAM_LENGTH,
X_PROGRAM_LENGTH_MEASUREMENT);
UPDATE_ROW (
X_ROWID,
X_COURSE_CD,
X_VERSION_NUMBER,
X_CAL_TYPE,
X_ATTENDANCE_MODE,
X_ATTENDANCE_TYPE,
X_LOCATION_CD,
X_COO_ID,
X_FORCED_LOCATION_IND,
X_FORCED_ATT_MODE_IND,
X_FORCED_ATT_TYPE_IND,
X_TIME_LIMITATION,
X_ENR_OFFICER_PERSON_ID,
X_ATTRIBUTE_CATEGORY,
X_ATTRIBUTE1,
X_ATTRIBUTE2,
X_ATTRIBUTE3,
X_ATTRIBUTE4,
X_ATTRIBUTE5,
X_ATTRIBUTE6,
X_ATTRIBUTE7,
X_ATTRIBUTE8,
X_ATTRIBUTE9,
X_ATTRIBUTE10,
X_ATTRIBUTE11,
X_ATTRIBUTE12,
X_ATTRIBUTE13,
X_ATTRIBUTE14,
X_ATTRIBUTE15,
X_ATTRIBUTE16,
X_ATTRIBUTE17,
X_ATTRIBUTE18,
X_ATTRIBUTE19,
X_ATTRIBUTE20,
X_MODE ,
X_PROGRAM_LENGTH,
X_PROGRAM_LENGTH_MEASUREMENT);
procedure DELETE_ROW (
X_ROWID in VARCHAR2
) AS
begin
Before_DML (
p_action => 'DELETE',
x_rowid => X_ROWID
);
delete from IGS_PS_OFR_OPT_ALL
where ROWID = X_ROWID;
p_action => 'DELETE',
x_rowid => X_ROWID
);
end DELETE_ROW;