शायद एक INDEX
है PRIMARY KEY CONSTRAINT
. से संबद्ध , और इसे PK_B
. के नाम से भी जाना जाता है ।
आप इसे इस प्रकार देख सकते हैं:
SELECT * FROM USER_INDEXES WHERE TABLE_NAME='<table_name>';
अगर यह सच है, तो करें:
ALTER INDEX "PK_B" RENAME TO "PK_XYZ";
अपडेट :ALTER INDEX
. के संबंध में बयान, कुछ महत्वपूर्ण बिंदु जैसा कि जस्टिन ने टिप्पणियों में उल्लेख किया है
Oracle परोक्ष रूप से एक UNIQUE
बनाता है PRIMARY KEY CONSTRAINT
. का समर्थन करने के लिए अनुक्रमणिका . चूंकि, अनुक्रमणिका प्राथमिक कुंजी के समान नाम की है, और अब जबकि प्राथमिक कुंजी को संशोधित किया जा रहा है, यह बेहतर है पुरानी प्राथमिक कुंजी की परिभाषा के अनुसार सूचकांक को फिर से गिराने और फिर से बनाने के लिए।
मेरा निष्कर्ष:
- प्राथमिक कुंजी बाधा एक अद्वितीय अनुक्रमणिका के माध्यम से लागू की जाती है।
- यदि Oracle पहले से ही एक अनुक्रमणिका पाता है - अद्वितीय या गैर-अद्वितीय - यह प्राथमिक कुंजी के लिए इसका उपयोग करता है।
- यदि अनुक्रमणिका प्रारंभ में गैर-अद्वितीय के रूप में बनाई गई थी, तो यह गैर-अद्वितीय के रूप में दिखाई देती रहेगी, हालांकि यह वास्तव में एक अद्वितीय अनुक्रमणिका होगी।
अरुप द्वारा एक अच्छा प्रदर्शन और अन्य पहलुओं पर भी काफी विस्तृत:प्राथमिक कुंजियाँ विशिष्टता की गारंटी देती हैं? फिर से सोचें।