2008-09-18 11 views
157

Ich habe einen Fremdschlüssel (in SQL Server) erstellt von:Wie lege ich einen Fremdschlüssel in SQL Server ab?

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

ich diese Abfrage dann auszuführen:

alter table company drop column CountryID; 

und ich bekomme diese Fehlermeldung:

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

Ich habe versuchte dies, aber es scheint nicht zu funktionieren:

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

Was muss ich tun, um die CountryID Spalte fallen zu lassen?

Danke.

+2

Welchen Fehler erhalten Sie, wenn Sie versuchen, den Fremdschlüssel zu löschen? – ddc0660

+0

Seien Sie sich bewusst, dass es gefährlich ist, einen Fremdschlüssel-Constraint zu löschen, ohne zu wissen, warum er an erster Stelle steht. Wenn Sie dies nur aus Versehen erstellt haben, verwenden Sie den in den anderen Antworten angegebenen Code. Wenn nicht, dann lassen Sie die Einschränkung nicht fallen, bis Sie sicher sind, dass Sie damit nicht etwas anderes brechen. Constraints werden erstellt, um Geschäftsregeln zu erzwingen und es ist besser sicher zu sein, dass sie nicht mehr benötigt werden, bevor sie gelöscht werden. – HLGEM

+0

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

Antwort

243

Versuchen

alter table company drop constraint Company_CountryID_FK 


alter table company drop column CountryID 
4

Ich weiß MSSQL nicht, aber wäre es nicht:

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

Diese Arbeit wird:

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

Sie können auch Rechtsklick Wählen Sie auf dem Tisch Modify, gehen Sie zu dem Attribut, klicken Sie mit der rechten Maustaste darauf und wählen Sie choo se den Primärschlüssel ablegen.

1

Versuchen Sie, die FK-Bedingung oder die Spalte selbst zu löschen?

die Einschränkung fallen:

alter table company drop constraint Company_CountryID_FK 

Sie fallen in der Lage, um die Spalte nicht, bis Sie die Einschränkung fallen.

15

Ich denke, das wird für Sie hilfreich ...

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) 

Es wird basierend auf bestimmten Tabellen- und Spaltenfremdschlüssel löschen.

+1

Danke Samir. Große Verallgemeinerung. – kuklei

13

Zuerst prüfen, ob die Beschränkung existiert, und dann ablegen.

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 
Verwandte Themen