sql >> Databasteknik >  >> RDS >> Oracle

Upptäck PL/SQL-paketnivåtyper med hjälp av Oracle-ordboksvyer

Endast från 11.1 och framåt.

Från manualen:

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 är ett kompilatordrivet verktyg som samlar in data om identifierare i PL/SQL-källkod vid programenhets kompileringstid och gör den tillgänglig i statisk dataordbok vyer. Den insamlade informationen inkluderar information om identifierartyper, användningsområden (deklaration, definition, referens, anrop, tilldelning) och platsen för varje användning i källkoden.

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. MariaDB LOCALTIME() Förklarad

  2. I MySQL, ska jag citera siffror eller inte?

  3. MySQL Inner Join Query Flera tabeller

  4. Hur man jämför prestanda för MySQL med SysBench