2008-09-18 8 views
157

मैंने एक विदेशी कुंजी (SQL सर्वर में) बनाई है:मैं SQL सर्वर में एक विदेशी कुंजी कैसे छोड़ूं?

alter table company add CountryID varchar(3); 
alter table company add constraint Company_CountryID_FK foreign key(CountryID) 
references Country; 

मैं फिर यह क्वेरी चलाता हूं:

alter table company drop column CountryID; 

और मुझे यह त्रुटि मिलती है:

Msg 5074, Level 16, State 4, Line 2
The object 'Company_CountryID_FK' is dependent on column 'CountryID'.
Msg 4922, Level 16, State 9, Line 2
ALTER TABLE DROP COLUMN CountryID failed because one or more objects access this column

मैंने कोशिश की है यह, अभी तक यह काम नहीं कर रहा है:

alter table company drop foreign key Company_CountryID_FK; 
alter table company drop column CountryID; 

CountryID कॉलम को छोड़ने के लिए मुझे क्या करने की आवश्यकता है?

धन्यवाद।

+2

क्या त्रुटि आप विदेशी कुंजी ड्रॉप करने की कोशिश कर सकते हैं? – ddc0660

+0

बस जागरूक रहें कि यह जानने के बिना एक विदेशी कुंजी बाधा को छोड़ना खतरनाक है कि यह पहले स्थान पर क्यों है। यदि आपने अभी इसे बनाया है और गलती से किया है तो अन्य उत्तरों में दिए गए कोड का उपयोग करें। यदि नहीं, तब तक बाधा न छोड़ें जब तक आप सुनिश्चित न हों कि आप ऐसा करके कुछ और नहीं तोड़ेंगे। बाधा नियमों को लागू करने के लिए बाधाएं बनाई गई हैं और यह सुनिश्चित करना बेहतर है कि उन्हें छोड़ने से पहले उन्हें अब आवश्यकता नहीं है। – HLGEM

+0

http://www.w3schools.com/sql/sql_foreignkey.asp – xameeramir

उत्तर

243

alter table company drop constraint Company_CountryID_FK 


alter table company drop column CountryID 
4

मैं MSSQL पता नहीं है की कोशिश करो, लेकिन यह नहीं होगा:

alter table company drop **constraint** Company_CountryID_FK; 
10
alter table company drop constraint Company_CountryID_FK 
44

यह काम करेगा:

ALTER TABLE [dbo].[company] DROP CONSTRAINT [Company_CountryID_FK] 
1

तुम भी राइट क्लिक कर सकते हैं तालिका पर, संशोधित करें चुनें, फिर विशेषता पर जाएं, राइट क्लिक करें, और choo प्राथमिक कुंजी छोड़ें।

1

क्या आप एफके बाधा या कॉलम को छोड़ने की कोशिश कर रहे हैं?

alter table company drop constraint Company_CountryID_FK 

आप जब तक आप बाधा ड्रॉप स्तंभ ड्रॉप करने में सक्षम नहीं होगा:

बाधा छोड़ें।

15

मैं तुम्हें करने के लिए उपयोगी इस वसीयत ...

DECLARE @ConstraintName nvarchar(200) 
SELECT 
    @ConstraintName = KCU.CONSTRAINT_NAME 
FROM INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS AS RC 
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS KCU 
    ON KCU.CONSTRAINT_CATALOG = RC.CONSTRAINT_CATALOG 
    AND KCU.CONSTRAINT_SCHEMA = RC.CONSTRAINT_SCHEMA 
    AND KCU.CONSTRAINT_NAME = RC.CONSTRAINT_NAME 
WHERE 
    KCU.TABLE_NAME = 'TABLE_NAME' AND 
    KCU.COLUMN_NAME = 'TABLE_COLUMN_NAME' 
IF @ConstraintName IS NOT NULL EXEC('alter table TABLE_NAME drop CONSTRAINT ' + @ConstraintName) 

यह विशिष्ट तालिका और स्तंभ के आधार पर विदेशी कुंजी बाधा को नष्ट करेगा लगता है।

+1

धन्यवाद समीर। महान सामान्यीकरण। – kuklei

13

बाधा के अस्तित्व की पहली जांच तो इसे छोड़ दें।

if exists (select 1 from sys.objects where name = 'Company_CountryID_FK' and type='F') 
begin 
alter table company drop constraint Company_CountryID_FK 
end 
संबंधित मुद्दे