Oracle: Data Dictionary

Greetings,

I have a new employee in my team and wanted to provide her with a data dictionary of all the table we are using.  Is there a way to do this easily?

Also, I would like to show a table's fields by showing the name and the type (number, Varchar, etc..)  Then I can pull the data into excel and create a data dictionary.

Is there a query that I can run?

Thanks!!

I am using Aqua data studio and Oracle Developer
Maliki HassaniAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Steve WalesSenior Database AdministratorCommented:
The following will get you a list of all your tables and their basic data layouts (looking somewhat like the output from a DESCRIBE command in SQLPlus:
set lines 132
set pages 10000
column table_name format a30
column column_name format a30
column data_type format a40
column nullable format a8

break on table_name skip 2;

select 
  table_name, 
  column_name,
  decode(data_type, 
   'VARCHAR2',data_type||'('||data_length||')',
   'CHAR'    ,data_type||'('||data_length||')',
   'NVARCHAR2'    ,data_type||'('||data_length||')',
   'NCHAR'    ,data_type||'('||data_length||')',
   'NUMBER' ,decode(data_precision, 
                    null, data_type, 
                    data_type||'('||data_precision||','||data_scale||')'),
   data_type) as DATA_TYPE,
  decode(nullable, 'Y', ' ', 'NOT NULL') as NULLABLE
from dba_tab_columns
where owner = 'MYSCHEMA'
order by table_name, column_id

Open in new window

0
slightwv (䄆 Netminder) Commented:
The SQL above should work.

Since this is a one time thing, I prefer SQL to generate a script and just execute the script:

set pages 0
set feedback off
spool mylist.sql
select 'desc ' || table_name from user_tables;
spool off

@mylist
0
Maliki HassaniAuthor Commented:
Okay great..  Should I be running this in Oracle SQL developer?
0
Powerful Yet Easy-to-Use Network Monitoring

Identify excessive bandwidth utilization or unexpected application traffic with SolarWinds Bandwidth Analyzer Pack.

Maliki HassaniAuthor Commented:
So I ran the top query in Developer but nothing is in the results section?
0
slightwv (䄆 Netminder) Commented:
The select should run wherever.

I believe the desc command will work in SQL Deverloper.  I don't use the GUI tools to I'm not 100% sure.
0
Maliki HassaniAuthor Commented:
Ahh there was a space in desc.  thanks
0
Steve WalesSenior Database AdministratorCommented:
Just to make sure you did it, make sure you change 'MYSCHEMA' to the name of the owner of your tables.

I just ran it in SQL Developer and it ran fine.

Alternatively if you don't have SYS/SYSTEM/DBA access, connect as the user who owns the tables, change dba_tab_columns to user_tab_columns, remove the where clause and run it.

In SQL Developer, everything before the "select" will be ignored (these are formatting options for SQL Plus).

As an alternative, since you want the output in Excel, you could just try opening Excel and using MSQuery (as ugly as that interface is) to drag the output you want directly into Excel - it's all there in user_tab_columns.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
Maliki HassaniAuthor Commented:
Brilliant!  You all are awesome!
0
Maliki HassaniAuthor Commented:
Thanks
0
Maliki HassaniAuthor Commented:
One more question though.   It only shows the tables/views that are in myschema.  How can I pull for all other tables?  I am also using the query for user_tab_columns and removing the where clause
0
slightwv (䄆 Netminder) Commented:
You'll need the DBA level views:  dba_tab_columns
and add a where:  where owner in ('MYSCHEMA','MYOTHERSCHEMA')

Oracle has 3 level for all of it's views:  DBA, ALL and USER.

DBA is everything.
ALL is everything you have permission to see.
USER is what you own.

So if you use a view say, USER_TABLES, there is also an ALL_TABLES and DBA_TABLES.  Same goes for all the other available Oracle provided views.
0
slightwv (䄆 Netminder) Commented:
I suppose I should also point out that just a list of tables and columns isn't all that useful to anyone.

What would make more sense is a physical model of the database complete with primary and foreign key relationships.

You can reverse engineer your database using SQL Developer Data Modeler:
http://www.oracle.com/technetwork/developer-tools/datamodeler/overview/index.html

Point it to a schema/database and let it generate the model.  Then all you'll need to do is move the tables around so it makes a nice pretty picture.
0
Maliki HassaniAuthor Commented:
Great! Thank you
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Oracle Database

From novice to tech pro — start learning today.