sql >> Databáze >  >> RDS >> Oracle

Objevte typy na úrovni balíčků PL/SQL pomocí pohledů slovníku Oracle

Pouze od 11.1.

Z návodu:

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 je kompilátorem řízený nástroj, který shromažďuje data o identifikátorech ve zdrojovém kódu PL/SQL v době kompilace programové jednotky a zpřístupňuje je ve statickém datovém slovníku pohledy. Shromážděná data zahrnují informace o typech identifikátorů, použití (deklarace, definice, reference, volání, přiřazení) a umístění každého použití ve zdrojovém kódu.

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. Získávání dat pomocí znakové sady UTF-8 ze serveru MSSQL pomocí rozšíření PHP FreeTDS

  2. Vyberte (načtěte) všechny záznamy z více schémat pomocí Postgres

  3. Jak mohu získat názvy sloupců z tabulky na serveru SQL?

  4. Jak nakonfigurovat AppArmor pro systémy založené na MySQL (MySQL/MariaDB Replication + Galera)