Oracle
 sql >> Datenbank >  >> RDS >> Oracle

So listen Sie alle Tabellen auf, die in einer bestimmten gespeicherten Prozedur in Oracle verwendet werden

Dynamic SQL s werden übersprungen, da sie in SEMANTIC nicht validiert sind Überprüfungen während der Kompilierung

select 
   proc_syn.referenced_owner, 
   proc_syn.referenced_name, 
   proc_syn.referenced_type,
   syn_tab.table_name
from 
   dba_dependencies proc_syn, dba_synonyms syn_tab, dba_tables tables
where 
     proc_syn.name= 'YOUR_PROC' 
  AND REFERENCED_TYPE in ( 'SYNONYM','TABLE')
  AND proc_syn.referenced_name = syn_tab.synonym_name
  AND syn_tab.synonym_name = tables.table_name
  AND syn_tab.owner = 'PUBLIC'
order by 
  proc_syn.referenced_owner, syn_tab.table_name;