आप DBA_/ALL_/USER_IND_COLUMNS
क्वेरी कर सकता है, यानि कि
SQL> SELECT index_name
2 FROM dba_ind_columns
3 WHERE table_owner = 'SCOTT'
4 AND table_name = 'EMP'
5 AND column_name = 'EMPNO';
INDEX_NAME
------------------------------
PK_EMP
बेशक
, आप क्वेरी थोड़ा विस्तार करने के लिए कर सकते हैं। यह किसी भी इंडेक्स को उठाएगा जिसमें ईएमपीएनओ कॉलम दिखाई देता है। आप खुद को इंडेक्स तक सीमित करना चाहते हैं जहां कॉलम इंडेक्स का अग्रणी कॉलम है (COLUMN_POSITION
= 1)। या आप खुद को उस विशेष कॉलम पर इंडेक्स तक सीमित करना चाहते हैं (ताकि COLUMN_POSITION
2 में कोई कॉलम न हो), यानी
SQL> ed
Wrote file afiedt.buf
1 SELECT index_name
2 FROM dba_ind_columns a
3 WHERE table_owner = 'SCOTT'
4 AND table_name = 'EMP'
5 AND column_name = 'EMPNO'
6 AND column_position = 1
7 AND NOT EXISTS(SELECT 1
8 FROM dba_ind_columns b
9 WHERE a.index_owner = b.index_owner
10 AND a.index_name = b.index_name
11* AND b.column_position = 2)
SQL>/
INDEX_NAME
------------------------------
PK_EMP
स्रोत
2008-11-20 21:24:12