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
) AS
CURSOR cur_old_ref_values IS
SELECT *
FROM IGS_AS_INS_GRD_ENTRY
WHERE rowid = x_rowid;
IF (cur_old_ref_values%NOTFOUND) AND (p_action NOT IN ('INSERT','VALIDATE_INSERT')) THEN
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 IGS_AS_INS_GRD_ENTRY
WHERE keying_who = x_keying_who
AND keying_time = x_keying_time
AND student_sequence = x_student_sequence
FOR UPDATE NOWAIT;
SELECT rowid
FROM IGS_AS_INS_GRD_ENTRY
WHERE grading_schema_cd = x_grading_schema_cd
AND gs_version_number = x_version_number
AND grade = x_grade ;
x_last_update_date IN DATE DEFAULT NULL,
x_last_updated_by IN NUMBER DEFAULT NULL,
x_last_update_login IN NUMBER DEFAULT NULL
) AS
BEGIN
Set_Column_Values (
p_action,
x_rowid,
x_keying_who,
x_keying_time,
x_student_sequence,
x_person_id,
x_name,
x_course_cd,
x_unit_cd,
x_version_number,
x_cal_type,
x_ci_sequence_number,
x_location_cd,
x_unit_class,
x_unit_attempt_status,
x_mark,
x_grading_schema_cd,
x_gs_version_number,
x_grade,
x_specified_grade_ind,
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.keying_who ,
NEW_REFERENCES.keying_time ,
NEW_REFERENCES.student_sequence) 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_Constraints;
ELSIF (p_action = 'VALIDATE_INSERT') THEN
IF Get_PK_For_Validation (
NEW_REFERENCES.keying_who ,
NEW_REFERENCES.keying_time ,
NEW_REFERENCES.student_sequence) THEN
Fnd_Message.Set_Name ('IGS', 'IGS_GE_RECORD_ALREADY_EXISTS');
ELSIF (p_action = 'VALIDATE_UPDATE') THEN
Check_Constraints;
procedure INSERT_ROW (
X_ROWID in out NOCOPY VARCHAR2,
X_KEYING_WHO in VARCHAR2,
X_KEYING_TIME in DATE,
X_STUDENT_SEQUENCE in NUMBER,
X_PERSON_ID in NUMBER,
X_NAME in VARCHAR2,
X_COURSE_CD in VARCHAR2,
X_UNIT_CD in VARCHAR2,
X_VERSION_NUMBER in NUMBER,
X_CAL_TYPE in VARCHAR2,
X_CI_SEQUENCE_NUMBER in NUMBER,
X_LOCATION_CD in VARCHAR2,
X_UNIT_CLASS in VARCHAR2,
X_UNIT_ATTEMPT_STATUS in VARCHAR2,
X_MARK in NUMBER,
X_GRADING_SCHEMA_CD in VARCHAR2,
X_GS_VERSION_NUMBER in NUMBER,
X_GRADE in VARCHAR2,
X_SPECIFIED_GRADE_IND in VARCHAR2,
X_MODE in VARCHAR2 default 'R'
) AS
cursor C is select ROWID from IGS_AS_INS_GRD_ENTRY
where KEYING_WHO = X_KEYING_WHO
and KEYING_TIME = X_KEYING_TIME
and STUDENT_SEQUENCE = X_STUDENT_SEQUENCE;
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_cal_type=>X_CAL_TYPE,
x_ci_sequence_number=>X_CI_SEQUENCE_NUMBER,
x_course_cd=>X_COURSE_CD,
x_grade=>X_GRADE,
x_grading_schema_cd=>X_GRADING_SCHEMA_CD,
x_gs_version_number=>X_GS_VERSION_NUMBER,
x_keying_time=>X_KEYING_TIME,
x_keying_who=>X_KEYING_WHO,
x_location_cd=>X_LOCATION_CD,
x_mark=>X_MARK,
x_name=>X_NAME,
x_person_id=>X_PERSON_ID,
x_specified_grade_ind=> NVL(X_SPECIFIED_GRADE_IND,'N'),
x_student_sequence=>X_STUDENT_SEQUENCE,
x_unit_attempt_status=>X_UNIT_ATTEMPT_STATUS,
x_unit_cd=>X_UNIT_CD,
x_unit_class=>X_UNIT_CLASS,
x_version_number=>X_VERSION_NUMBER,
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 IGS_AS_INS_GRD_ENTRY (
KEYING_WHO,
KEYING_TIME,
STUDENT_SEQUENCE,
PERSON_ID,
NAME,
COURSE_CD,
UNIT_CD,
VERSION_NUMBER,
CAL_TYPE,
CI_SEQUENCE_NUMBER,
LOCATION_CD,
UNIT_CLASS,
UNIT_ATTEMPT_STATUS,
MARK,
GRADING_SCHEMA_CD,
GS_VERSION_NUMBER,
GRADE,
SPECIFIED_GRADE_IND,
CREATION_DATE,
CREATED_BY,
LAST_UPDATE_DATE,
LAST_UPDATED_BY,
LAST_UPDATE_LOGIN
) values (
NEW_REFERENCES.KEYING_WHO,
NEW_REFERENCES.KEYING_TIME,
NEW_REFERENCES.STUDENT_SEQUENCE,
NEW_REFERENCES.PERSON_ID,
NEW_REFERENCES.NAME,
NEW_REFERENCES.COURSE_CD,
NEW_REFERENCES.UNIT_CD,
NEW_REFERENCES.VERSION_NUMBER,
NEW_REFERENCES.CAL_TYPE,
NEW_REFERENCES.CI_SEQUENCE_NUMBER,
NEW_REFERENCES.LOCATION_CD,
NEW_REFERENCES.UNIT_CLASS,
NEW_REFERENCES.UNIT_ATTEMPT_STATUS,
NEW_REFERENCES.MARK,
NEW_REFERENCES.GRADING_SCHEMA_CD,
NEW_REFERENCES.GS_VERSION_NUMBER,
NEW_REFERENCES.GRADE,
NEW_REFERENCES.SPECIFIED_GRADE_IND,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_DATE,
X_LAST_UPDATED_BY,
X_LAST_UPDATE_LOGIN
);
end INSERT_ROW;
cursor c1 is select
PERSON_ID,
NAME,
COURSE_CD,
UNIT_CD,
VERSION_NUMBER,
CAL_TYPE,
CI_SEQUENCE_NUMBER,
LOCATION_CD,
UNIT_CLASS,
UNIT_ATTEMPT_STATUS,
MARK,
GRADING_SCHEMA_CD,
GS_VERSION_NUMBER,
GRADE,
SPECIFIED_GRADE_IND
from IGS_AS_INS_GRD_ENTRY
where ROWID = X_ROWID for update nowait;
fnd_message.set_name('FND', 'FORM_RECORD_DELETED');
procedure UPDATE_ROW (
X_ROWID in VARCHAR2,
X_KEYING_WHO in VARCHAR2,
X_KEYING_TIME in DATE,
X_STUDENT_SEQUENCE in NUMBER,
X_PERSON_ID in NUMBER,
X_NAME in VARCHAR2,
X_COURSE_CD in VARCHAR2,
X_UNIT_CD in VARCHAR2,
X_VERSION_NUMBER in NUMBER,
X_CAL_TYPE in VARCHAR2,
X_CI_SEQUENCE_NUMBER in NUMBER,
X_LOCATION_CD in VARCHAR2,
X_UNIT_CLASS in VARCHAR2,
X_UNIT_ATTEMPT_STATUS in VARCHAR2,
X_MARK in NUMBER,
X_GRADING_SCHEMA_CD in VARCHAR2,
X_GS_VERSION_NUMBER in NUMBER,
X_GRADE in VARCHAR2,
X_SPECIFIED_GRADE_IND in VARCHAR2,
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_cal_type=>X_CAL_TYPE,
x_ci_sequence_number=>X_CI_SEQUENCE_NUMBER,
x_course_cd=>X_COURSE_CD,
x_grade=>X_GRADE,
x_grading_schema_cd=>X_GRADING_SCHEMA_CD,
x_gs_version_number=>X_GS_VERSION_NUMBER,
x_keying_time=>X_KEYING_TIME,
x_keying_who=>X_KEYING_WHO,
x_location_cd=>X_LOCATION_CD,
x_mark=>X_MARK,
x_name=>X_NAME,
x_person_id=>X_PERSON_ID,
x_specified_grade_ind=>X_SPECIFIED_GRADE_IND,
x_student_sequence=>X_STUDENT_SEQUENCE,
x_unit_attempt_status=>X_UNIT_ATTEMPT_STATUS,
x_unit_cd=>X_UNIT_CD,
x_unit_class=>X_UNIT_CLASS,
x_version_number=>X_VERSION_NUMBER,
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_AS_INS_GRD_ENTRY set
PERSON_ID = NEW_REFERENCES.PERSON_ID,
NAME = NEW_REFERENCES.NAME,
COURSE_CD = NEW_REFERENCES.COURSE_CD,
UNIT_CD = NEW_REFERENCES.UNIT_CD,
VERSION_NUMBER = NEW_REFERENCES.VERSION_NUMBER,
CAL_TYPE = NEW_REFERENCES.CAL_TYPE,
CI_SEQUENCE_NUMBER = NEW_REFERENCES.CI_SEQUENCE_NUMBER,
LOCATION_CD = NEW_REFERENCES.LOCATION_CD,
UNIT_CLASS = NEW_REFERENCES.UNIT_CLASS,
UNIT_ATTEMPT_STATUS = NEW_REFERENCES.UNIT_ATTEMPT_STATUS,
MARK = NEW_REFERENCES.MARK,
GRADING_SCHEMA_CD = NEW_REFERENCES.GRADING_SCHEMA_CD,
GS_VERSION_NUMBER = NEW_REFERENCES.GS_VERSION_NUMBER,
GRADE = NEW_REFERENCES.GRADE,
SPECIFIED_GRADE_IND = NEW_REFERENCES.SPECIFIED_GRADE_IND,
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;
end UPDATE_ROW;
cursor c1 is select rowid from IGS_AS_INS_GRD_ENTRY
where KEYING_WHO = X_KEYING_WHO
and KEYING_TIME = X_KEYING_TIME
and STUDENT_SEQUENCE = X_STUDENT_SEQUENCE
;
INSERT_ROW (
X_ROWID,
X_KEYING_WHO,
X_KEYING_TIME,
X_STUDENT_SEQUENCE,
X_PERSON_ID,
X_NAME,
X_COURSE_CD,
X_UNIT_CD,
X_VERSION_NUMBER,
X_CAL_TYPE,
X_CI_SEQUENCE_NUMBER,
X_LOCATION_CD,
X_UNIT_CLASS,
X_UNIT_ATTEMPT_STATUS,
X_MARK,
X_GRADING_SCHEMA_CD,
X_GS_VERSION_NUMBER,
X_GRADE,
X_SPECIFIED_GRADE_IND,
X_MODE);
UPDATE_ROW (
X_ROWID,
X_KEYING_WHO,
X_KEYING_TIME,
X_STUDENT_SEQUENCE,
X_PERSON_ID,
X_NAME,
X_COURSE_CD,
X_UNIT_CD,
X_VERSION_NUMBER,
X_CAL_TYPE,
X_CI_SEQUENCE_NUMBER,
X_LOCATION_CD,
X_UNIT_CLASS,
X_UNIT_ATTEMPT_STATUS,
X_MARK,
X_GRADING_SCHEMA_CD,
X_GS_VERSION_NUMBER,
X_GRADE,
X_SPECIFIED_GRADE_IND,
X_MODE);
procedure DELETE_ROW (
X_ROWID in VARCHAR2) AS
begin
Before_DML(
p_action => 'DELETE',
x_rowid => X_ROWID
);
delete from IGS_AS_INS_GRD_ENTRY
where ROWID = X_ROWID;
end DELETE_ROW;