WITH looking_for(l_owner, l_name) AS (
SELECT UPPER('&owner'), UPPER('&object_name') FROM dual
),
dep AS (
SELECT 'DBA_DEPENDENCIES' info_from, d.owner, d.name, d.type, CAST(d.dependency_type AS VARCHAR2(4000)) note
FROM dba_dependencies d, looking_for
WHERE d.referenced_name = l_name AND d.owner = l_owner
),
dba_source_with_owner AS (
SELECT 'DBA_SOURCE with owner', d.owner, d.name, d.type, NULL
FROM dba_source d, looking_for
WHERE regexp_like(text, '(^|[^A-Z0-9#$_]+)' || l_owner || '.' || l_name , 'i')
AND NOT (d.name = l_name AND d.owner <> l_owner)
),
dba_source_wo_owner AS (
SELECT 'DBA_SOURCE without owner', d.owner, d.name, d.type, NULL
FROM dba_source d, looking_for
WHERE regexp_like(text, '(^|[^A-Z0-9#$_]+)' || l_name , 'i')
AND d.owner = l_owner
AND d.name <> l_name
),
jobs AS (
SELECT 'DBMS_JOB', d.priv_user, to_char(d.job), NULL, d.what
FROM dba_jobs d, looking_for
WHERE regexp_like(what, '(^|[^A-Z0-9#$_]+)' || l_name , 'i')
),
schedules AS (
SELECT 'DBA_SCHEDULER_JOBS.JOB_ACTION', d.owner, d.job_name, job_type, d.job_action
FROM dba_scheduler_jobs d, looking_for
WHERE regexp_like(job_action, '(^|[^A-Z0-9#$_]+)' || l_name , 'i')
),
schedules_programs AS (
SELECT 'DBA_SCHEDULER_PROGRAMS.PROGRAM_ACTION', d.owner, d.program_name, program_type, program_action
FROM dba_scheduler_programs d, looking_for
WHERE regexp_like(program_action, '(^|[^A-Z0-9#$_]+)' || l_name , 'i')
),
privs AS (
SELECT 'DBA_TAB_PRIVS' info_from, NULL, grantee, 'ROLE', PRIVILEGE note
FROM dba_tab_privs d, looking_for
WHERE d.table_name = l_name AND d.owner = l_owner
),
policy AS (
SELECT 'DBA_POLICIES' info_from, NULL, d.policy_name, 'POLICY FOR ' || d.object_owner || '.' || d.object_name, pf_owner || '.' || d.package || '.' || d.function note
FROM dba_policies d, looking_for
WHERE d.pf_owner = l_owner
AND (d.package = l_name OR d.function = l_name)
),
sql_plan AS (
SELECT 'SQLPLAN', NULL AS owner, NULL AS NAME, 'HIST_SQL' AS TYPE, TO_CHAR(SUBSTR(t.sql_text, 1, 4000))
FROM looking_for, dba_hist_sql_plan p, dba_hist_sqltext t
WHERE p.object_owner = l_owner
AND p.object_name = l_name
AND p.sql_id = t.sql_id(+)
UNION
SELECT 'SQLPLAN', NULL AS owner, NULL AS NAME, 'INDEX_HIST_SQL' AS TYPE, TO_CHAR(SUBSTR(t.sql_text, 1, 4000))
FROM dba_hist_sql_plan p, dba_hist_sqltext t
WHERE (object_owner, object_name) IN (SELECT owner, index_name FROM dba_indexes, looking_for WHERE table_name = l_name AND owner = l_owner)
AND p.sql_id = t.sql_id(+)
UNION
SELECT 'SQLPLAN', NULL AS owner, NULL AS NAME, 'SQL' AS TYPE, TO_CHAR(SUBSTR(t.sql_fulltext, 1, 4000))
FROM looking_for, v$sql_plan p, v$sql t
WHERE p.object_owner = l_owner
AND p.object_name = l_name
AND p.sql_id = t.sql_id(+)
UNION
SELECT 'SQLPLAN', NULL AS owner, NULL AS NAME, 'INDEX_SQL' AS TYPE, TO_CHAR(SUBSTR(t.sql_fulltext, 1, 4000))
FROM looking_for, v$sql_plan p, v$sql t
WHERE (object_owner, object_name) IN (SELECT owner, index_name FROM dba_indexes, looking_for WHERE table_name = l_name AND owner = l_owner)
AND p.sql_id = t.sql_id(+)
),
tab_modifications AS (
SELECT 'DBA_TAB_MODIFICATIONS' info_from, NULL AS owner, NULL AS NAME, 'Was modified on: ' || TO_CHAR(TIMESTAMP, 'DD.MM.YYYY HH24:MI:SS'),
'Inserts: ' || inserts || '; Updates: ' || updates || '; Deletes: ' || deletes || '; Truncated ' || truncated note
FROM dba_tab_modifications d, looking_for
WHERE d.table_owner = l_owner
AND d.table_name = l_name
)
SELECT /*+ PARALLEL(4)*/* FROM dep
UNION ALL
SELECT * FROM dba_source_with_owner
UNION ALL
SELECT * FROM dba_source_wo_owner t WHERE NOT EXISTS (SELECT NULL FROM dba_source_with_owner i WHERE i.owner = t.owner AND i.name = t.name)
UNION ALL
SELECT * FROM jobs
UNION ALL
SELECT * FROM schedules
UNION ALL
SELECT * FROM schedules_programs
UNION ALL
SELECT * FROM privs
UNION ALL
SELECT * FROM policy
UNION ALL
SELECT * FROM sql_plan
UNION ALL
SELECT * FROM tab_modifications
;