The following lines contain the word 'select', 'insert', 'update' or 'delete':
select
subjects_taken_id
,language
,source_lang
,grade_attained
from per_subjects_taken_tl
where subjects_taken_id = p_subjects_taken_id
and language = p_language;
select
subjects_taken_id
,language
,source_lang
,grade_attained
from per_subjects_taken_tl
where subjects_taken_id = p_subjects_taken_id
and language = p_language
for update nowait;
delete from PER_SUBJECTS_TAKEN_TL T
where not exists
(select NULL
from PER_SUBJECTS_TAKEN B
where B.SUBJECTS_TAKEN_ID = T.SUBJECTS_TAKEN_ID
);
update PER_SUBJECTS_TAKEN_TL T set (
GRADE_ATTAINED
) = (select
B.GRADE_ATTAINED
from PER_SUBJECTS_TAKEN_TL B
where B.SUBJECTS_TAKEN_ID = T.SUBJECTS_TAKEN_ID
and B.LANGUAGE = T.SOURCE_LANG)
where (
T.SUBJECTS_TAKEN_ID,
T.LANGUAGE
) in (select
SUBT.SUBJECTS_TAKEN_ID,
SUBT.LANGUAGE
from PER_SUBJECTS_TAKEN_TL SUBB, PER_SUBJECTS_TAKEN_TL SUBT
where SUBB.SUBJECTS_TAKEN_ID = SUBT.SUBJECTS_TAKEN_ID
and SUBB.LANGUAGE = SUBT.SOURCE_LANG
and (SUBB.GRADE_ATTAINED <> SUBT.GRADE_ATTAINED
or (SUBB.GRADE_ATTAINED is null and SUBT.GRADE_ATTAINED is not null)
or (SUBB.GRADE_ATTAINED is not null and SUBT.GRADE_ATTAINED is null)
));
insert into PER_SUBJECTS_TAKEN_TL (
SUBJECTS_TAKEN_ID,
GRADE_ATTAINED,
CREATED_BY,
CREATION_DATE,
LAST_UPDATED_BY,
LAST_UPDATE_DATE,
LAST_UPDATE_LOGIN,
LANGUAGE,
SOURCE_LANG
) select
B.SUBJECTS_TAKEN_ID,
B.GRADE_ATTAINED,
B.CREATED_BY,
B.CREATION_DATE,
B.LAST_UPDATED_BY,
B.LAST_UPDATE_DATE,
B.LAST_UPDATE_LOGIN,
L.LANGUAGE_CODE,
B.SOURCE_LANG
from PER_SUBJECTS_TAKEN_TL B, FND_LANGUAGES L
where L.INSTALLED_FLAG in ('I', 'B')
and B.LANGUAGE = userenv('LANG')
and not exists
(select NULL
from PER_SUBJECTS_TAKEN_TL T
where T.SUBJECTS_TAKEN_ID = B.SUBJECTS_TAKEN_ID
and T.LANGUAGE = L.LANGUAGE_CODE);