The following lines contain the word 'select', 'insert', 'update' or 'delete':
x_last_update_date IN DATE DEFAULT NULL,
x_last_updated_by IN NUMBER DEFAULT NULL,
x_last_update_login IN NUMBER DEFAULT NULL ,
x_org_id IN NUMBER DEFAULT NULL
) AS
CURSOR cur_old_ref_values IS
SELECT *
FROM IGS_GR_CRMN_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 BeforeRowInsertUpdate1(
p_inserting IN BOOLEAN DEFAULT FALSE,
p_updating IN BOOLEAN DEFAULT FALSE,
p_deleting IN BOOLEAN DEFAULT FALSE
) AS
v_message_name VARCHAR2(30);
-- Validate the graduation ceremony record can be updated
IF p_updating THEN
IF (new_references.ceremony_dt_alias <> old_references.ceremony_dt_alias OR
new_references.ceremony_dai_sequence_number <> old_references.ceremony_dai_sequence_number OR
new_references.closing_dt_alias <> old_references.closing_dt_alias OR
new_references.closing_dai_sequence_number <> old_references.closing_dai_sequence_number) THEN
IF IGS_GR_VAL_GC.grdp_val_gc_upd(
new_references.grd_cal_type,
new_references.grd_ci_sequence_number,
new_references.ceremony_number,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS', v_message_name);
IF p_inserting OR (p_updating AND new_references.venue_cd <> old_references.venue_cd) THEN
-- Validate venue is related to a location with a s_location_type of grd_ctr
IF IGS_GR_VAL_GC.grdp_val_ve_lot(
new_references.venue_cd,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS', v_message_name);
IF p_inserting OR (p_updating AND
(new_references.ceremony_dt_alias <> old_references.ceremony_dt_alias OR
new_references.ceremony_dai_sequence_number <> old_references.ceremony_dai_sequence_number OR
new_references.closing_dt_alias <> old_references.closing_dt_alias OR
new_references.closing_dai_sequence_number <> old_references.closing_dai_sequence_number)) THEN
-- Validate the graduation ceremony date aliases
IF IGS_GR_VAL_GC.grdp_val_gc_dai(
new_references.grd_cal_type,
new_references.grd_ci_sequence_number,
new_references.ceremony_dt_alias,
new_references.ceremony_dai_sequence_number,
new_references.closing_dt_alias,
new_references.closing_dai_sequence_number,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS', v_message_name);
END BeforeRowInsertUpdate1;
PROCEDURE AfterRowInsertUpdate2(
p_inserting IN BOOLEAN DEFAULT FALSE,
p_updating IN BOOLEAN DEFAULT FALSE,
p_deleting IN BOOLEAN DEFAULT FALSE
) AS
v_message_name VARCHAR2(30);
IF p_inserting OR (p_updating AND
(new_references.ceremony_start_time <> old_references.ceremony_start_time OR
new_references.ceremony_end_time <> old_references.ceremony_end_time)) THEN
-- validate graduation ceremony start and end times
IF IGS_GR_VAL_GC.grdp_val_gc_times(
NEW_REFERENCES.grd_cal_type,
NEW_REFERENCES.grd_ci_sequence_number,
NEW_REFERENCES.ceremony_number,
NEW_REFERENCES.venue_cd,
NEW_REFERENCES.ceremony_dt_alias,
NEW_REFERENCES.ceremony_dai_sequence_number,
NEW_REFERENCES.ceremony_start_time,
NEW_REFERENCES.ceremony_end_time,
v_message_name) = FALSE THEN
Fnd_Message.Set_Name('IGS', v_message_name);
END AfterRowInsertUpdate2;
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 rowid
FROM IGS_GR_CRMN_ALL
WHERE grd_cal_type = x_grd_cal_type
AND grd_ci_sequence_number = x_grd_ci_sequence_number
AND ceremony_number = x_ceremony_number
FOR UPDATE NOWAIT;
SELECT rowid
FROM IGS_GR_CRMN_ALL
WHERE (ceremony_dt_alias = x_dt_alias
AND ceremony_dai_sequence_number = x_sequence_number
AND grd_cal_type = x_cal_type
AND grd_ci_sequence_number = x_ci_sequence_number)
OR (closing_dt_alias = x_dt_alias
AND closing_dai_sequence_number = x_sequence_number
AND grd_cal_type = x_cal_type
AND grd_ci_sequence_number = x_ci_sequence_number) ;
SELECT rowid
FROM IGS_GR_CRMN_ALL
WHERE grd_cal_type = x_grd_cal_type
AND grd_ci_sequence_number = x_grd_ci_sequence_number ;
SELECT rowid
FROM IGS_GR_CRMN_ALL
WHERE venue_cd = x_venue_cd ;
x_last_update_date IN DATE DEFAULT NULL,
x_last_updated_by IN NUMBER DEFAULT NULL,
x_last_update_login IN NUMBER DEFAULT NULL,
x_org_id IN NUMBER DEFAULT NULL
) AS
BEGIN
Set_Column_Values (
p_action,
x_rowid,
x_grd_cal_type,
x_grd_ci_sequence_number,
x_ceremony_number,
x_venue_cd,
x_ceremony_dt_alias,
x_ceremony_dai_sequence_number,
x_closing_dt_alias,
x_closing_dai_sequence_number,
x_ceremony_start_time,
x_ceremony_end_time,
x_ceremony_fee,
x_number_of_guests,
x_creation_date,
x_created_by,
x_last_update_date,
x_last_updated_by,
x_last_update_login ,
x_org_id
);
IF (p_action = 'INSERT') THEN
-- Call all the procedures related to Before Insert.
BeforeRowInsertUpdate1 ( p_inserting => TRUE );
ELSIF (p_action = 'UPDATE') THEN
-- Call all the procedures related to Before Update.
BeforeRowInsertUpdate1 ( p_updating => TRUE );
ELSIF (p_action = 'DELETE') THEN
-- Call all the procedures related to Before Delete.
Check_Child_Existance;
ELSIF (p_action = 'VALIDATE_INSERT') THEN
IF GET_PK_FOR_VALIDATION(
NEW_REFERENCES.grd_cal_type,
NEW_REFERENCES.grd_ci_sequence_number,
NEW_REFERENCES.ceremony_number
) THEN
Fnd_Message.Set_Name('IGS','IGS_GE_MULTI_ORG_DUP_REC');
ELSIF (p_action = 'VALIDATE_UPDATE') THEN
check_constraints;
ELSIF (p_action = 'VALIDATE_DELETE') THEN
check_child_existance;
IF (p_action = 'INSERT') THEN
-- Call all the procedures related to After Insert.
AfterRowInsertUpdate2 ( p_inserting => TRUE );
ELSIF (p_action = 'UPDATE') THEN
-- Call all the procedures related to After Update.
AfterRowInsertUpdate2 ( p_updating => TRUE );
procedure INSERT_ROW (
X_ROWID in out NOCOPY VARCHAR2,
X_GRD_CAL_TYPE in VARCHAR2,
X_GRD_CI_SEQUENCE_NUMBER in NUMBER,
X_CEREMONY_NUMBER in NUMBER,
X_VENUE_CD in VARCHAR2,
X_CEREMONY_DT_ALIAS in VARCHAR2,
X_CEREMONY_DAI_SEQUENCE_NUMBER in NUMBER,
X_CLOSING_DT_ALIAS in VARCHAR2,
X_CLOSING_DAI_SEQUENCE_NUMBER in NUMBER,
X_CEREMONY_START_TIME in DATE,
X_CEREMONY_END_TIME in DATE,
X_CEREMONY_FEE in NUMBER,
X_NUMBER_OF_GUESTS in NUMBER,
X_MODE in VARCHAR2 default 'R',
X_ORG_ID in NUMBER
) AS
cursor C is select ROWID from IGS_GR_CRMN_ALL
where GRD_CAL_TYPE = X_GRD_CAL_TYPE
and GRD_CI_SEQUENCE_NUMBER = X_GRD_CI_SEQUENCE_NUMBER
and CEREMONY_NUMBER = X_CEREMONY_NUMBER;
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_grd_cal_type => X_GRD_CAL_TYPE,
x_grd_ci_sequence_number => X_GRD_CI_SEQUENCE_NUMBER,
x_ceremony_number => X_CEREMONY_NUMBER,
x_venue_cd => X_VENUE_CD,
x_ceremony_dt_alias => X_CEREMONY_DT_ALIAS,
x_ceremony_dai_sequence_number => X_CEREMONY_DAI_SEQUENCE_NUMBER,
x_closing_dt_alias => X_CLOSING_DT_ALIAS,
x_closing_dai_sequence_number => X_CLOSING_DAI_SEQUENCE_NUMBER,
x_ceremony_start_time => X_CEREMONY_START_TIME,
x_ceremony_end_time => X_CEREMONY_END_TIME,
x_ceremony_fee => X_CEREMONY_FEE,
x_number_of_guests => X_NUMBER_OF_GUESTS,
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
);
insert into IGS_GR_CRMN_ALL (
GRD_CAL_TYPE,
GRD_CI_SEQUENCE_NUMBER,
CEREMONY_NUMBER,
VENUE_CD,
CEREMONY_DT_ALIAS,
CEREMONY_DAI_SEQUENCE_NUMBER,
CLOSING_DT_ALIAS,
CLOSING_DAI_SEQUENCE_NUMBER,
CEREMONY_START_TIME,
CEREMONY_END_TIME,
CEREMONY_FEE,
NUMBER_OF_GUESTS,
CREATION_DATE,
CREATED_BY,
LAST_UPDATE_DATE,
LAST_UPDATED_BY,
LAST_UPDATE_LOGIN,
ORG_ID
) values (
NEW_REFERENCES.GRD_CAL_TYPE,
NEW_REFERENCES.GRD_CI_SEQUENCE_NUMBER,
NEW_REFERENCES.CEREMONY_NUMBER,
NEW_REFERENCES.VENUE_CD,
NEW_REFERENCES.CEREMONY_DT_ALIAS,
NEW_REFERENCES.CEREMONY_DAI_SEQUENCE_NUMBER,
NEW_REFERENCES.CLOSING_DT_ALIAS,
NEW_REFERENCES.CLOSING_DAI_SEQUENCE_NUMBER,
NEW_REFERENCES.CEREMONY_START_TIME,
NEW_REFERENCES.CEREMONY_END_TIME,
NEW_REFERENCES.CEREMONY_FEE,
NEW_REFERENCES.NUMBER_OF_GUESTS,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_LOGIN,
NEW_REFERENCES.ORG_ID
);
p_action => 'INSERT',
x_rowid => X_ROWID
);
end INSERT_ROW;
cursor c1 is select
VENUE_CD,
CEREMONY_DT_ALIAS,
CEREMONY_DAI_SEQUENCE_NUMBER,
CLOSING_DT_ALIAS,
CLOSING_DAI_SEQUENCE_NUMBER,
CEREMONY_START_TIME,
CEREMONY_END_TIME,
CEREMONY_FEE,
NUMBER_OF_GUESTS
from IGS_GR_CRMN_ALL
where ROWID = X_ROWID for update nowait;
fnd_message.set_name('FND', 'FORM_RECORD_DELETED');
procedure UPDATE_ROW (
X_ROWID in VARCHAR2,
X_GRD_CAL_TYPE in VARCHAR2,
X_GRD_CI_SEQUENCE_NUMBER in NUMBER,
X_CEREMONY_NUMBER in NUMBER,
X_VENUE_CD in VARCHAR2,
X_CEREMONY_DT_ALIAS in VARCHAR2,
X_CEREMONY_DAI_SEQUENCE_NUMBER in NUMBER,
X_CLOSING_DT_ALIAS in VARCHAR2,
X_CLOSING_DAI_SEQUENCE_NUMBER in NUMBER,
X_CEREMONY_START_TIME in DATE,
X_CEREMONY_END_TIME in DATE,
X_CEREMONY_FEE in NUMBER,
X_NUMBER_OF_GUESTS in NUMBER,
X_MODE in VARCHAR2 default 'R'
) 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_grd_cal_type => X_GRD_CAL_TYPE,
x_grd_ci_sequence_number => X_GRD_CI_SEQUENCE_NUMBER,
x_ceremony_number => X_CEREMONY_NUMBER,
x_venue_cd => X_VENUE_CD,
x_ceremony_dt_alias => X_CEREMONY_DT_ALIAS,
x_ceremony_dai_sequence_number => X_CEREMONY_DAI_SEQUENCE_NUMBER,
x_closing_dt_alias => X_CLOSING_DT_ALIAS,
x_closing_dai_sequence_number => X_CLOSING_DAI_SEQUENCE_NUMBER,
x_ceremony_start_time => X_CEREMONY_START_TIME,
x_ceremony_end_time => X_CEREMONY_END_TIME,
x_ceremony_fee => X_CEREMONY_FEE,
x_number_of_guests => X_NUMBER_OF_GUESTS,
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
);
update IGS_GR_CRMN_ALL set
VENUE_CD = NEW_REFERENCES.VENUE_CD,
CEREMONY_DT_ALIAS = NEW_REFERENCES.CEREMONY_DT_ALIAS,
CEREMONY_DAI_SEQUENCE_NUMBER = NEW_REFERENCES.CEREMONY_DAI_SEQUENCE_NUMBER,
CLOSING_DT_ALIAS = NEW_REFERENCES.CLOSING_DT_ALIAS,
CLOSING_DAI_SEQUENCE_NUMBER = NEW_REFERENCES.CLOSING_DAI_SEQUENCE_NUMBER,
CEREMONY_START_TIME = NEW_REFERENCES.CEREMONY_START_TIME,
CEREMONY_END_TIME = NEW_REFERENCES.CEREMONY_END_TIME,
CEREMONY_FEE = NEW_REFERENCES.CEREMONY_FEE,
NUMBER_OF_GUESTS = NEW_REFERENCES.NUMBER_OF_GUESTS,
LAST_UPDATE_DATE = X_LAST_UPDATE_DATE,
LAST_UPDATED_BY = X_LAST_UPDATED_BY,
LAST_UPDATE_LOGIN = X_LAST_UPDATE_LOGIN
where ROWID = X_ROWID
;
p_action => 'UPDATE',
x_rowid => X_ROWID
);
end UPDATE_ROW;
cursor c1 is select rowid from IGS_GR_CRMN_ALL
where GRD_CAL_TYPE = X_GRD_CAL_TYPE
and GRD_CI_SEQUENCE_NUMBER = X_GRD_CI_SEQUENCE_NUMBER
and CEREMONY_NUMBER = X_CEREMONY_NUMBER
;
INSERT_ROW (
X_ROWID,
X_GRD_CAL_TYPE,
X_GRD_CI_SEQUENCE_NUMBER,
X_CEREMONY_NUMBER,
X_VENUE_CD,
X_CEREMONY_DT_ALIAS,
X_CEREMONY_DAI_SEQUENCE_NUMBER,
X_CLOSING_DT_ALIAS,
X_CLOSING_DAI_SEQUENCE_NUMBER,
X_CEREMONY_START_TIME,
X_CEREMONY_END_TIME,
X_CEREMONY_FEE,
X_NUMBER_OF_GUESTS,
X_MODE,
x_org_id
);
UPDATE_ROW (
X_ROWID,
X_GRD_CAL_TYPE,
X_GRD_CI_SEQUENCE_NUMBER,
X_CEREMONY_NUMBER,
X_VENUE_CD,
X_CEREMONY_DT_ALIAS,
X_CEREMONY_DAI_SEQUENCE_NUMBER,
X_CLOSING_DT_ALIAS,
X_CLOSING_DAI_SEQUENCE_NUMBER,
X_CEREMONY_START_TIME,
X_CEREMONY_END_TIME,
X_CEREMONY_FEE,
X_NUMBER_OF_GUESTS,
X_MODE
);
procedure DELETE_ROW (
X_ROWID in VARCHAR2
) AS
begin
Before_DML (
p_action => 'DELETE',
x_rowid => X_ROWID
);
delete from IGS_GR_CRMN_ALL
where ROWID = X_ROWID;
end DELETE_ROW;