Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Odkryj typy pakietów PL/SQL, korzystając z widoków słownika Oracle

Tylko od 11.1.

Z instrukcji:

http://download.oracle.com/docs/cd/E11882_01/appdev.112/e17125/adfns_plscope.htm#ADFNS02204

http://download.oracle.com/docs/cd/E11882_01/server.112/e17110/initparams189.htm#REFRN10271

PL/Scope to narzędzie oparte na kompilatorze, które zbiera dane o identyfikatorach w kodzie źródłowym PL/SQL w czasie kompilacji jednostki programowej i udostępnia je w słowniku danych statycznych wyświetlenia. Zgromadzone dane obejmują informacje o typach identyfikatorów, zastosowaniach (deklaracja, definicja, odniesienie, wywołanie, przypisanie) oraz lokalizację każdego użycia w kodzie źródłowym.

DEMO

CREATE OR REPLACE PACKAGE my_types AS
  TYPE t_cursor_type IS REF CURSOR;
  TYPE t_table_type IS TABLE OF employees%rowtype;
  type t_associative is table number index by  varchar2(20);
END my_types;

alter package  my_types compile plscope_settings='IDENTIFIERS:ALL' reuse settings;

select *
from   user_identifiers ui
where  ui.object_type = 'PACKAGE'
and    ui.usage = 'DECLARATION'
and    ui.usage_context_id = '1';


NAME                           SIGNATURE                        TYPE               OBJECT_NAME                    OBJECT_TYPE   USAGE         USAGE_ID       LINE        COL USAGE_CONTEXT_ID
------------------------------ -------------------------------- ------------------ ------------------------------ ------------- ----------- ---------- ---------- ---------- ----------------
T_ASSOCIATIVE                  9A18FE6BCB72110F39CED9E08B932ECB ASSOCIATIVE ARRAY  MY_TYPES                       PACKAGE       DECLARATION          4          4          8                1
T_TABLE_TYPE                   77067FE9732B492C166D38221DC3DF37 NESTED TABLE       MY_TYPES                       PACKAGE       DECLARATION          3          3          8                1
T_CURSOR_TYPE                  EDEC9260784B7721BC3F3DAB293F23DD REFCURSOR          MY_TYPES                       PACKAGE       DECLARATION          2          2          8                1

[email protected]> 


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Czy w ORACLE istnieje sposób na połączenie wielu wierszy w jeden, przy użyciu dwóch tabel, w których końcowe wartości są oddzielone przecinkami?

  2. Zagnieżdżone łączenie pętli w Oracle 11g

  3. Słowo kluczowe Oracle „Partition By” i „Row_Number”

  4. Jak zmienić format daty w sesji Oracle

  5. ORA-24550:odebrany sygnał:[si_signo=6] błąd