จะรับคอลัมน์คีย์หลักใน Oracle ได้อย่างไร


108

ฉันต้องการชื่อของคอลัมน์คีย์หลัก

ในอินพุตฉันมีเพียงชื่อตารางเท่านั้น

คำตอบ:


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;

ตรวจสอบให้แน่ใจว่า "TABLE_NAME" เป็นตัวพิมพ์ใหญ่เนื่องจาก Oracle เก็บชื่อตารางเป็นตัวพิมพ์ใหญ่


ขอบคุณริชชี่ อีกหนึ่งคำถาม: จะเข้ารหัส 'P' ได้อย่างไร? ฉันต้องการดำเนินการนี้ด้วย "ดำเนินการทันที" ขอบคุณอีกครั้ง.
Kirill A.

4
ฉันคิดว่าคุณจะใส่เครื่องหมายคำพูดเดี่ยวสองคำไว้รอบ ๆ แบบนี้ '' P ''
Greg Reynolds

หรือคุณสามารถพูดมัน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

2
@FearlessFuture ฉันคิดว่าข้อ จำกัด ที่คุณกำลังค้นหาไม่ใช่ข้อ จำกัด ของผู้ใช้ แทนที่user_constraintsโดยall_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;

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 = cols.constraint_name and CONSTRAINTYPE ' = '<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.