Como obter coluna de chave primária no Oracle?

107

Preciso obter o nome da coluna da chave primária.

Na entrada, tenho apenas o nome da tabela.

Kirill A.
fonte

Respostas:

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;

Certifique-se de que 'TABLE_NAME' esteja em maiúsculas, pois o Oracle armazena os nomes das tabelas em maiúsculas.

Richie
fonte
Obrigado, Richie. Mais uma pergunta: como codificar 'P'? Preciso executar isso com "EXECUTE IMMEDIATE". thnx novamente.
Kirill A.
4
Acho que você colocaria apenas duas aspas simples ao redor, assim '' P ''
Greg Reynolds
Alternativamente, você pode citá-lo usando q.
Burhan Ali
e constraint_type = 'R' para chave estrangeira
Abinash Bishoyi
Funcionou para mim quando não tinha o prefixo do esquema antes da mesa! Obrigado!
FearlessFuture
20

O mesmo que a resposta de 'Richie', mas um pouco mais conciso.

  1. Consultar apenas as restrições do usuário

    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. Consulta para todas as restrições

    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'
    );
Meu nome é
fonte
@FearlessFuture Para mim funcionou bem. Você pode descrever seu problema de forma um pouco mais expressiva?
My-Name-Is
Não obtenho nenhum resultado desta consulta, mas obtenho resultados da consulta para a resposta aceita.
FearlessFuture
2
@FearlessFuture Presumo que a restrição que você está procurando não seja uma restrição do usuário. Substitua user_constraintspor all_constraints.
My-Name-Is
Isso causa problemas se você tiver uma tabela com o mesmo nome em dois ou mais esquemas - também é necessário incluir o proprietário na junção: 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 Concordo que a segunda consulta não funcionará. Mas sua solução é ineficiente. Tente: "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 = cols.constraint_name = 'cols.constraint_name e CONSTRAINT_TY' e CONSTRAINT_TY ' = '<TABLE_NAME>' e cons.table_name = cols.table_name; "
Alexander Heim
2
Select constraint_name,constraint_type from user_constraints where table_name** **= TABLE_NAME ;

(Isso listará a chave primária e, em seguida)

Select column_name,position from user_cons_cloumns where constraint_name=’PK_XYZ’; 

(Isso fornecerá a coluna, aqui PK_XYZ é o nome da chave primária)

Vipin Tiwari
fonte
1

Tente este código Aqui eu criei uma tabela para obter a coluna de chave primária no oracle que é chamada de teste e consulta

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;
Kobir
fonte
0

Salve o seguinte script como algo como 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');

Ele pode então ser chamado usando

@findPK
Bugalugs Nash
fonte