什么是查询来获取表描述以及带有标记为主键的列的列的查询?例如,它将返回如下内容:
Table Column is_part_of_pk
----- ------ -------------
ADDRESS ID 1
ADDRESS ADDR_LINE_1 0
ADDRESS ADDR_CITY 0
STUDENT FIRST_NAME 1
STUDENT LAST_NAME 1
STUDENT CLASS_NAME 0
列出了表中的所有列,并且对属于或属于主键的列进行了“标记”。我试图针对user_tab_columns,all_cons_columns和all_constraints进行选择,但是我得到了重复的列。谢谢。
试试这个
select col.table_name , col.column_name,
case when exists(select 'x' from USER_CONSTRAINTS l
join USER_CONS_COLUMNS ll on LL.CONSTRAINT_NAME = L.CONSTRAINT_NAME
where l.table_name = col.table_name and l.constraint_type = 'P' and ll.column_name = col.column_name) then 1 else 0 end is_part_of_pk
from USER_TAB_COLUMNS col where table_name = :some_table_name
order by column_id;
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句