Oracle에서 기본 키 열을 얻는 방법은 무엇입니까?


107

기본 키 열의 이름을 가져와야합니다.

입력에는 테이블 이름 만 있습니다.

답변:


190
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'이 대문자인지 확인하십시오.


고마워, 리치. 한 가지 더 질문 : 'P'를 인코딩하는 방법? "EXECUTE IMMEDIATE"로 이것을 실행해야합니다. 다시 thnx.
Kirill A.

4
나는 당신이 두 따옴표가 '같이'P '를 모아 둘 것입니다 생각
그렉 레이놀즈

또는 사용하여 인용 할 수 q있습니다.
Burhan Ali

외부 키와의 CONSTRAINT_TYPE = 'R'
Abinash Bishoyi

테이블 앞에 스키마 접두사가 없을 때 나를 위해 일했습니다! 감사!
FearlessFuture

20

'Richie'의 답변과 동일하지만 좀 더 간결합니다.

  1. 사용자 제약 만 쿼리

    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'
    );
  2. 모든 제약 조건에 대한 쿼리

    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'
    );

@FearlessFuture 저에게는 잘 작동했습니다. 문제를 좀 더 표현 적으로 설명 할 수 있습니까?
My-Name-Is

이 쿼리에서 어떤 결과도 얻지 못했지만 허용 된 답변에 대한 쿼리에서 결과를 얻었습니다.
FearlessFuture 2015

2
@FearlessFuture 나는 당신이 찾고있는 제약이 사용자 제약이 아니라고 가정합니다. 교체 user_constraintsall_constraints.
My-Name-Is

두 개 이상의 스키마에 같은 이름의 테이블이있는 경우 문제가 발생합니다. 조인에도 소유자를 포함해야합니다. SELECT owner, column_name, position FROM all_cons_columns WHERE (owner, constraint_name) in (SELECT owner, constraint_name FROM all_constraints WHERE UPPER(table_name) = UPPER('&tableName') AND CONSTRAINT_TYPE = 'P') order by owner, position;
Mark Stewart

1
@MarkStewart 두 번째 쿼리가 작동하지 않는다는 데 동의합니다. 그러나 귀하의 솔루션은 비효율적입니다. 시도 : "SELECT cols.column_name AS KEY_STREAM, '='AS KEY_CONDITION, cols.column_name as KEY_LOOKUP, ''AS KEY_STREAM2 FROM user_constraints cons, user_cons_columns cols WHERE cons.constraint_name 'and cons.constraint_name = cols.constraint_name = '<TABLE_NAME>'및 cons.table_name = cols.table_name; "
Alexander Heim

2
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는 기본 키 이름입니다.)


1

이 코드를 시도해보십시오. 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;

0

다음 스크립트를 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
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.