2008-09-18 5 views
157

J'ai créé une clé étrangère (dans SQL Server) par:Comment supprimer une clé étrangère dans SQL Server?

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

Je lance alors cette requête:

alter table company drop column CountryID; 

et je reçois cette erreur:

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

Je essayé cela, mais il ne semble pas fonctionner:

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

Que dois-je faire pour supprimer la colonne CountryID?

Merci.

+2

Quelle erreur obtenez-vous en essayant de supprimer la clé étrangère? – ddc0660

+0

Sachez qu'il est dangereux d'abandonner une contrainte de clé étrangère sans savoir pourquoi elle est là en premier lieu. Si vous venez de créer ceci et que vous l'avez fait par erreur, utilisez le code fourni dans les autres réponses. Si ce n'est pas le cas, ne lâchez pas la contrainte tant que vous n'êtes pas sûr de ne pas casser autre chose. Les contraintes sont créées pour appliquer les règles de bus et il est préférable de s'assurer qu'elles ne sont plus nécessaires avant de les supprimer. – HLGEM

+0

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

Répondre

243

Essayez

alter table company drop constraint Company_CountryID_FK 


alter table company drop column CountryID 
4

Je ne sais pas MSSQL, mais serait-il pas:

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

Cela fonctionne:

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

Vous pouvez également Clic droit sur la table, choisissez modifier, puis allez à l'attribut, faites un clic droit dessus, et choo se drop clé primaire.

1

Essayez-vous de supprimer la contrainte FK ou la colonne elle-même?

Pour supprimer la contrainte:

alter table company drop constraint Company_CountryID_FK 

Vous ne pourrez pas laisser tomber la colonne jusqu'à ce que vous laissez tomber la contrainte.

15

Je pense que cela est utile pour vous ...

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) 

Il supprimera clé étrangère basée sur la table et la colonne spécifique.

+1

Merci Samir. Grande généralisation. – kuklei

13

Première vérification de l'existence de la contrainte, puis abandon.

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 
Questions connexes