sql >> Database teknologi >  >> RDS >> Oracle

Oplev typer på PL/SQL-pakkeniveau ved hjælp af Oracle-ordbogsvisninger

Kun fra den 11.1 og frem.

Fra 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 er et compiler-drevet værktøj, der indsamler data om identifikatorer i PL/SQL-kildekoden på programenheds kompileringstidspunkt og gør det tilgængeligt i statisk dataordbog visninger. De indsamlede data omfatter oplysninger om identifikatortyper, anvendelser (erklæring, definition, reference, opkald, tildeling) og placeringen af ​​hver brug i kildekoden.

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. Postgresql rekursiv selv joinforbindelse

  2. Databaseautomatisering bag Sveriges nye elektroniske identitet Freja eID

  3. Tilslutning af SAS JMP til Salesforce.com

  4. Administration af høj tilgængelighed i PostgreSQL – Del II:Replikeringsmanager