기본 키 열의 이름을 가져와야합니다.
입력에는 테이블 이름 만 있습니다.
답변
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;
Oracle은 테이블 이름을 대문자로 저장하므로 ‘TABLE_NAME’이 대문자인지 확인하십시오.
답변
‘Richie’의 답변과 동일하지만 좀 더 간결합니다.
-
사용자 제약 만 쿼리
SELECT column_name FROM all_cons_columns WHERE constraint_name = ( SELECT constraint_name FROM user_constraints WHERE UPPER(table_name) = UPPER('tableName') AND CONSTRAINT_TYPE = 'P' );
-
모든 제약 조건에 대한 쿼리
SELECT column_name FROM all_cons_columns WHERE constraint_name = ( SELECT constraint_name FROM all_constraints WHERE UPPER(table_name) = UPPER('tableName') AND CONSTRAINT_TYPE = 'P' );
답변
Select constraint_name,constraint_type from user_constraints where table_name** **= ‘TABLE_NAME’ ;
(이것은 기본 키를 나열한 다음)
Select column_name,position from user_cons_cloumns where constraint_name=’PK_XYZ’;
(이것은 열을 제공합니다. 여기서 PK_XYZ는 기본 키 이름입니다.)
답변
이 코드를 시도해보십시오. Oracle에서 테스트라는 기본 키 열을 가져 오는 테이블을 만든 다음 쿼리
create table test
(
id int,
name varchar2(20),
city varchar2(20),
phone int,
constraint pk_id_name_city primary key (id,name,city)
);
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 = 'TEST' AND cons.constraint_type = 'P' AND cons.constraint_name = cols.constraint_name AND cons.owner = cols.owner ORDER BY cols.table_name, cols.position;
답변
다음 스크립트를 findPK.sql과 같은 파일로 저장하십시오.
set verify off
accept TABLE_NAME char prompt 'Table name>'
SELECT cols.column_name
FROM all_constraints cons NATURAL JOIN all_cons_columns cols
WHERE cons.constraint_type = 'P' AND table_name = UPPER('&TABLE_NAME');
그런 다음 다음을 사용하여 호출 할 수 있습니다.
@findPK