7

Does anybody know how to query for a primary key of a table in Oracle 11g? I saw a similar question for SQL Server, but I've had no luck from trying the answers on that thread.

Thanks!

nikow
  • 21,190
  • 7
  • 49
  • 70
web_novice118
  • 111
  • 1
  • 3
  • 4

2 Answers2

13

As the user that owns the table you can do:

select constraint_name, status, deferrable, deferred, validated, generated 
from user_constraints 
where constraint_type = 'P' and table_name = 'Table Name'

Update: I think this gets you what you need.

SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner
FROM all_constraints cons, all_cons_columns cols
WHERE cols.table_name = 'Table Name'
AND cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner
ORDER BY cols.table_name, cols.position

You can check this site for more details.

Jacob Schoen
  • 14,034
  • 15
  • 82
  • 102
1
SELECT cols.table_name
  ||' - '
  ||cols.column_name primary_key
FROM all_constraints cons,
  all_cons_columns cols,
  user_tables ut
WHERE cons.constraint_type = 'P'
AND cons.constraint_name   = cols.constraint_name
AND cons.owner             = cols.owner
AND cols.table_name        = ut.table_name
ORDER BY cols.table_name;
Mandeep Singh Gill
  • 1,145
  • 9
  • 5