A: Query the TEXT column of table DBA_VIEWS.
Syntax:
SQL> set long 10000
SQL> select TEXT
2 FROM DBA_VIEWS
3 where OWNER = '<owner_name>'
4 and VIEW_NAME = '<view_name>';
Here is an example:
% sqlplus fs890/fs890@fs890
SQL> create table PERSON (
2 SSN VARCHAR2(12),
3 FIRST_NAME VARCHAR2(25),
4 LAST_NAME VARCHAR2(25),
5 STREET VARCHAR2(40),
6 CITY VARCHAR2(30),
7 STATE VARCHAR2(30),
8 ZIP VARCHAR2(15),
9 COUNTRY VARCHAR2(35));
Table created.
SQL> create view PERSON_VW as
2 select SSN, FIRST_NAME, LAST_NAME from PERSON;
View created.
SQL> set long 1000
SQL> select TEXT
2 from DBA_VIEWS
3 where OWNER = 'FS890'
4 and VIEW_NAME = 'PERSON_VW';
TEXT
--------------------------------------------------------------------------------
SELECT SSN, FIRST_NAME, LAST_NAME FROM PERSON
Q#2: How to get the current {session} user and current schema name?
A: Run the following query:
select sys_context('USERENV', 'SESSION_USER') SESSION_USER, sys_context('USERENV', 'CURRENT_SCHEMA') CURRENT_SCHEMA from dual;
Alternatively run
select USER from DUAL;
to find the current {session} user name.sys_context()
function returns the value of parameter associated with the context namespace. USERENV
is an Oracle provided namespace that describes the current session. Check the table Predefined Parameters of Namespace USERENV for the list of parameters and the expected return values.eg.,
SQL> column SESSION_USER format A15
SQL> column CURRENT_SEHEMA format A15
SQL> select sys_context('USERENV', 'SESSION_USER') SESSION_USER,
2 sys_context('USERENV', 'CURRENT_SCHEMA') CURRENT_SCHEMA from dual;
SESSION_USER CURRENT_SCHEMA
--------------- ---------------
FS890 FS890
SQL> column USER format A6
SQL> select USER from DUAL;
USER
------
FS890
Q#3: How to extract the table definition (DDL statements) from an Oracle database without having to go through a stack of dictionary views?
A: By calling the
GET_DDL()
function of metadata package DBMS_METADATA
.Syntax:
select DBMS_METADATA.GET_DDL('TABLE','<table_name>') from DUAL;
eg.,
SQL> set long 1000
SQL> set pagesize 0
SQL> select DBMS_METADATA.GET_DDL('TABLE','PERSON') from DUAL;
CREATE TABLE "FS890"."PERSON"
( "SSN" VARCHAR2(12),
"FIRST_NAME" VARCHAR2(25),
"LAST_NAME" VARCHAR2(25),
"STREET" VARCHAR2(40),
"CITY" VARCHAR2(30),
"STATE" VARCHAR2(30),
"ZIP" VARCHAR2(15),
"COUNTRY" VARCHAR2(35)
) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING
STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENT
S 2147483645
PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT
)
TABLESPACE "PSDEFAULT"
Q#4: How to extract the index definition (DDL statements) from an Oracle database without having to go through a stack of dictionary views?
A: By calling the
GET_DDL()
function of metadata package DBMS_METADATA
.Syntax:
select DBMS_METADATA.GET_DDL('INDEX','<index_name>') from DUAL;
eg.,
SQL> create index PERSON_IDX on PERSON ( SSN );
Index created.
SQL> set long 1000
SQL> set pagesize 0
SQL> select DBMS_METADATA.GET_DDL('INDEX','PERSON_IDX') from DUAL;
CREATE INDEX "FS890"."PERSON_IDX" ON "FS890"."PERSON" ("SSN")
PCTFREE 10 INITRANS 2 MAXTRANS 255
STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MA
XEXTENTS 2147483645
PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL
DEFAULT)
TABLESPACE "PSDEFAULT"
If the interest is only to get the indexed column names for an index, simply query COLUMN_NAME of table USER_IND_COLUMNS.
Syntax:
select COLUMN_NAME from USER_IND_COLUMNS where INDEX_NAME = '<index_name>';
eg.,
SQL> column COLUMN_NAME format A15________________
SQL> select COLUMN_NAME from USER_IND_COLUMNS where INDEX_NAME = 'PERSON_IDX';
COLUMN_NAME
---------------
SSN
Technorati tags:
Oracle | Database | SQL | DBA
Many thanks for the post. The information really saved me a lot of time.
ReplyDeleteGiri,
ReplyDeleteThanks a lot for this post. Helped me a lot in my work since we keep getting requests to provide view definitions. saved us a lot of time and effort.
The post is really informative...
ReplyDeletethanks so much! You saved me lots of time!!
ReplyDeleteHi!
ReplyDeleteselect from dba_views returns
select using Dbms_Metadata.Get_Ddl() returns
Do you know why?
:)
ReplyDelete1)"Long"
2)"CLOB"
Great! Precisely what I need. Thanks for the good work. I need to find out database definitions for my maintenance work.
ReplyDeleteThanks for the post. It helped me.
ReplyDeleteI googled and googled to find out how to get the definition of a view. FINALLY I found it here. I just wanted to say Thank You!
ReplyDeleteThanks Very Much!
ReplyDeletejust do
ReplyDeleteselect dbms_metadata.get_ddl('VIEW','VIEW_NAME','SCHEMA') from dual;
very simple son
This post is very helpful. Thanks a lot!
ReplyDeleteThank you so very much! It worked and it saved me a lot of time!
ReplyDeleteNice sql queries on oracle view
ReplyDeleteAwesome work