The following lines contain the word 'select', 'insert', 'update' or 'delete':
| Procedure insert_row |
| |
+======================================================================*/
PROCEDURE insert_row
(x_rowid IN OUT NOCOPY VARCHAR2
,x_analytical_criterion_code IN VARCHAR2
,x_analytical_criterion_type_co IN VARCHAR2
,x_amb_context_code IN VARCHAR2
,x_analytical_detail_code IN VARCHAR2
,x_grouping_order IN NUMBER
,x_data_type_code IN VARCHAR2
,x_name IN VARCHAR2
,x_description IN VARCHAR2
,x_creation_date IN DATE
,x_created_by IN NUMBER
,x_last_update_date IN DATE
,x_last_updated_by IN NUMBER
,x_last_update_login IN NUMBER)
IS
CURSOR c IS
SELECT rowid
FROM xla_analytical_dtls_b
WHERE analytical_criterion_code = x_analytical_criterion_code
AND analytical_criterion_type_code = x_analytical_criterion_type_co
AND amb_context_code = x_amb_context_code
AND analytical_detail_code = x_analytical_detail_code
;
l_log_module := C_DEFAULT_MODULE||'.insert_row';
trace(p_msg => 'BEGIN of procedure insert_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
INSERT INTO xla_analytical_dtls_b
(creation_date
,created_by
,analytical_criterion_code
,analytical_criterion_type_code
,amb_context_code
,analytical_detail_code
,grouping_order
,data_type_code
,last_update_date
,last_updated_by
,last_update_login)
VALUES
(x_creation_date
,x_created_by
,x_analytical_criterion_code
,x_analytical_criterion_type_co
,x_amb_context_code
,x_analytical_detail_code
,x_grouping_order
,x_data_type_code
,x_last_update_date
,x_last_updated_by
,x_last_update_login)
;
INSERT INTO xla_analytical_dtls_tl
(analytical_criterion_code
,analytical_criterion_type_code
,amb_context_code
,analytical_detail_code
,name
,description
,creation_date
,created_by
,last_update_date
,last_updated_by
,last_update_login
,language
,source_lang)
SELECT
x_analytical_criterion_code
,x_analytical_criterion_type_co
,x_amb_context_code
,x_analytical_detail_code
,x_name
,x_description
,x_creation_date
,x_created_by
,x_last_update_date
,x_last_updated_by
,x_last_update_login
,l.language_code
,USERENV('LANG')
FROM fnd_languages l
WHERE l.installed_flag IN ('I', 'B')
AND NOT EXISTS
(SELECT NULL
FROM xla_analytical_dtls_tl t
WHERE t.analytical_criterion_code = x_analytical_criterion_code
AND t.analytical_criterion_type_code = x_analytical_criterion_type_co
AND t.amb_context_code = x_amb_context_code
AND t.analytical_detail_code = x_analytical_detail_code
AND t.language = l.language_code);
trace(p_msg => 'END of procedure insert_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
END insert_row;
SELECT analytical_criterion_code
,grouping_order
,data_type_code
FROM xla_analytical_dtls_b
WHERE analytical_criterion_code = x_analytical_criterion_code
AND analytical_criterion_type_code = x_analytical_criterion_type_co
AND amb_context_code = x_amb_context_code
AND analytical_detail_code = x_analytical_detail_code
FOR UPDATE OF analytical_criterion_code NOWAIT;
SELECT analytical_criterion_code
,name
,description
,DECODE(language , USERENV('LANG'), 'Y', 'N') baselang
FROM xla_analytical_dtls_tl
WHERE analytical_criterion_code = X_analytical_criterion_code
AND analytical_criterion_type_code = X_analytical_criterion_type_co
AND amb_context_code = X_amb_context_code
AND analytical_detail_code = X_analytical_detail_code
AND USERENV('LANG') IN (language ,source_lang)
FOR UPDATE OF analytical_criterion_code NOWAIT;
fnd_message.set_name('FND', 'FORM_RECORD_DELETED');
| Procedure update_row |
| |
+======================================================================*/
PROCEDURE update_row
(x_analytical_criterion_code IN VARCHAR2
,x_analytical_criterion_type_co IN VARCHAR2
,x_amb_context_code IN VARCHAR2
,x_analytical_detail_code IN VARCHAR2
,x_grouping_order IN NUMBER
,x_data_type_code IN VARCHAR2
,x_name IN VARCHAR2
,x_description IN VARCHAR2
,x_last_update_date IN DATE
,x_last_updated_by IN NUMBER
,x_last_update_login IN NUMBER)
IS
l_log_module VARCHAR2(240);
l_log_module := C_DEFAULT_MODULE||'.update_row';
trace(p_msg => 'BEGIN of procedure update_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
UPDATE xla_analytical_dtls_b
SET
last_update_date = x_last_update_date
,grouping_order = x_grouping_order
,data_type_code = x_data_type_code
,last_updated_by = x_last_updated_by
,last_update_login = x_last_update_login
WHERE analytical_criterion_code = X_analytical_criterion_code
AND analytical_criterion_type_code = X_analytical_criterion_type_co
AND amb_context_code = X_amb_context_code
AND analytical_detail_code = X_analytical_detail_code;
UPDATE xla_analytical_dtls_tl
SET
last_update_date = x_last_update_date
,name = X_name
,description = X_description
,last_updated_by = x_last_updated_by
,last_update_login = x_last_update_login
,source_lang = USERENV('LANG')
WHERE analytical_criterion_code = X_analytical_criterion_code
AND analytical_criterion_type_code = X_analytical_criterion_type_co
AND amb_context_code = X_amb_context_code
AND analytical_detail_code = X_analytical_detail_code
AND USERENV('LANG') IN (language, source_lang);
trace(p_msg => 'END of procedure update_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
END update_row;
| Procedure delete_row |
| |
+======================================================================*/
PROCEDURE delete_row
(x_analytical_criterion_code IN VARCHAR2
,x_analytical_criterion_type_co IN VARCHAR2
,x_amb_context_code IN VARCHAR2
,x_analytical_detail_code IN VARCHAR2)
IS
l_log_module VARCHAR2(240);
l_log_module := C_DEFAULT_MODULE||'.delete_row';
trace(p_msg => 'BEGIN of procedure delete_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
DELETE FROM xla_analytical_dtls_tl
WHERE analytical_criterion_code = x_analytical_criterion_code
AND analytical_criterion_type_code = x_analytical_criterion_type_co
AND amb_context_code = x_amb_context_code
AND analytical_detail_code = x_analytical_detail_code;
DELETE FROM xla_analytical_dtls_b
WHERE analytical_criterion_code = x_analytical_criterion_code
AND analytical_criterion_type_code = x_analytical_criterion_type_co
AND amb_context_code = x_amb_context_code
AND analytical_detail_code = x_analytical_detail_code;
trace(p_msg => 'END of procedure delete_row',
p_module => l_log_module,
p_level => C_LEVEL_PROCEDURE);
END delete_row;
DELETE FROM xla_analytical_dtls_tl T
WHERE NOT EXISTS
(SELECT NULL
FROM xla_analytical_dtls_b b
WHERE b.analytical_criterion_code = t.analytical_criterion_code
AND b.analytical_criterion_type_code = t.analytical_criterion_type_code
AND b.amb_context_code = t.amb_context_code
AND b.analytical_detail_code = t.analytical_detail_code);
UPDATE xla_analytical_dtls_tl t
SET (name
,description)
= (SELECT b.name
,b.description
FROM xla_analytical_dtls_tl b
WHERE b.analytical_criterion_code = t.analytical_criterion_code
AND b.analytical_criterion_type_code = t.analytical_criterion_type_code
AND b.amb_context_code = t.amb_context_code
AND b.analytical_detail_code = t.analytical_detail_code
AND b.language = t.source_lang)
WHERE (t.analytical_criterion_code
,t.analytical_criterion_type_code
,t.amb_context_code
,t.analytical_detail_code
,t.language)
IN (SELECT subt.analytical_criterion_code
,subt.analytical_criterion_type_code
,subt.amb_context_code
,subt.analytical_detail_code
,subt.language
FROM xla_analytical_dtls_tl subb
,xla_analytical_dtls_tl subt
WHERE subb.analytical_criterion_code = subt.analytical_criterion_code
AND subb.analytical_criterion_type_code = subt.analytical_criterion_type_code
AND subb.amb_context_code = subt.amb_context_code
AND subb.analytical_detail_code = subt.analytical_detail_code
AND subb.language = subt.source_lang
AND (SUBB.name <> SUBT.name
OR SUBB.description <> SUBT.description
OR (subb.description IS NULL
AND subt.description IS NOT NULL)
OR (subb.description IS NOT NULL
AND subt.description IS NULL)
))
;
INSERT INTO xla_analytical_dtls_tl
(analytical_criterion_code
,analytical_criterion_type_code
,amb_context_code
,analytical_detail_code
,name
,description
,creation_date
,created_by
,last_update_date
,last_updated_by
,last_update_login
,language
,source_lang)
SELECT /*+ ORDERED */
b.analytical_criterion_code
,b.analytical_criterion_type_code
,b.amb_context_code
,b.analytical_detail_code
,b.name
,b.description
,b.creation_date
,b.created_by
,b.last_update_date
,b.last_updated_by
,b.last_update_login
,l.language_code
,b.source_lang
FROM xla_analytical_dtls_tl b
,fnd_languages l
WHERE l.installed_flag IN ('I', 'B')
AND b.language = userenv('LANG')
AND NOT EXISTS
(SELECT NULL
FROM xla_analytical_dtls_tl t
WHERE t.analytical_criterion_code = b.analytical_criterion_code
AND t.analytical_criterion_type_code = b.analytical_criterion_type_code
AND t.amb_context_code = b.amb_context_code
AND t.analytical_detail_code = b.analytical_detail_code
AND t.language = l.language_code);
,p_last_update_date IN VARCHAR2
,p_custom_mode IN VARCHAR2)
IS
l_rowid ROWID;
f_ludate DATE; -- entity update date in file
db_ludate DATE; -- entity update date in db
f_ludate := nvl(to_date(p_last_update_date, 'YYYY/MM/DD'), sysdate);
SELECT last_updated_by, last_update_date
INTO db_luby, db_ludate
FROM xla_analytical_dtls_tl
WHERE amb_context_code = p_amb_context_code
AND analytical_criterion_type_code = p_analytical_criterion_type_co
AND analytical_criterion_code = p_analytical_criterion_code
AND analytical_detail_code = p_analytical_detail_code
AND language = userenv('LANG');
UPDATE xla_analytical_dtls_tl
SET name = p_name
,description = p_description
,last_update_date = f_ludate
,last_updated_by = f_luby
,last_update_login = 0
,source_lang = userenv('LANG')
WHERE userenv('LANG') IN (language, source_lang)
AND amb_context_code = p_amb_context_code
AND analytical_criterion_type_code = p_analytical_criterion_type_co
AND analytical_criterion_code = p_analytical_criterion_code
AND analytical_detail_code = p_analytical_detail_code;