Oracle'da birincil anahtar sütunu nasıl elde edilir?


108

Birincil anahtar sütununun adını almam gerekiyor.

Girişte sadece tablo adına sahibim.

Yanıtlar:


191
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 tablo adlarını büyük harfle sakladığından 'TABLE_NAME' büyük harfle yazılmalıdır.


Teşekkürler Richie. Bir soru daha: 'P' nasıl kodlanır? Bunu "EXECUTE IMMEDIATE" ile yürütmem gerekiyor. tekrar teşekkürler.
Kirill A.

4
Sanırım etrafına şu '' P '' şeklinde iki tek tırnak koyarsınız
Greg Reynolds

Alternatif olarak, kullanarak alıntı yapabilirsiniz q.
Burhan Ali

ve yabancı anahtar için constraint_type = 'R'
Abinash Bishoyi

Tablodan önce şema öneki olmadığında benim için çalıştı! Teşekkürler!
FearlessFuture

20

Richie'nin cevabı ile aynı ama biraz daha özlü.

  1. Yalnızca kullanıcı kısıtlamaları için sorgu

    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. Tüm kısıtlamalar için sorgulama

    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 Benim için iyi çalıştı. Sorununuzu biraz daha anlamlı tanımlayabilir misiniz?
My-Name-Is

Bu sorgudan herhangi bir sonuç alamıyorum, ancak kabul edilen yanıt için sorgudan sonuç alıyorum.
FearlessFuture

2
@FearlessFuture Aradığınız kısıtlamanın bir kullanıcı kısıtlaması olmadığını varsayıyorum. Değiştir user_constraintstarafından all_constraints.
My-Name-Is

Bu, iki veya daha fazla şemada aynı ada sahip bir tablonuz varsa soruna neden olur - birleşime sahibi de eklemeniz gerekir: 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 İkinci Sorgunun çalışmayacağını kabul ediyorum. Ancak çözümünüz verimsiz. Deneyin: "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 sütunları WHERE cons.constraint_name = cols.constraint_name ve 'PSTRAINT_TYPE' = '<TABLE_NAME>' ve cons.table_name = cols.table_name; "
Alexander Heim

2
Select constraint_name,constraint_type from user_constraints where table_name** **= TABLE_NAME ;

(Bu birincil anahtarı listeleyecek ve sonra)

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

(Bu size sütunu verecektir, burada PK_XYZ birincil anahtar adıdır)


1

Bu Kodu Burada Deneyin Oracle'da birincil anahtar sütununu almak için test adı verilen ve ardından sorgu adı verilen bir tablo oluşturdum

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

Aşağıdaki komut dosyasını findPK.sql gibi kaydedin.

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

Daha sonra kullanılarak çağrılabilir

@findPK
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.