0

我已经尝试解决这个问题几个小时了,但我不知道是什么原因造成的。我正在尝试在 MSSQL Server 中删除表(我需要从头开始)以及每当我使用该语句时

DROP TABLE dbo.Manages;

我收到这条消息:

无法删除对象“dbo.Manages”,因为它被 FOREIGN KEY 约束引用。

问题是,我还剩下三个表,它们都包含外键(它们相互链接)。事实证明,我也无法删除,我被卡住了。我尝试先删除外键,但是

ALTER TABLE dbo.Manages DROP FOREIGN KEY Mgr_start_date;

行不通。我知道还有一种方法可以这样写:

ALTER TABLE dbo.Manages
DROP FOREIGN KEY fk_(...)

然而,当我创建外键时,我没有使用 fk_,我只是简单地说

ALTER TABLE dbo.Department
    ADD FOREIGN KEY (Mgr_start_date)
    REFERENCES dbo.Manages(Mgr_start_date);

任何帮助将不胜感激。我对 SQL 很陌生,但我真的很想完成这项工作。我尝试了这个论坛的一些解决方案,比如使用FOREIGN_KEY_CHECKS = 0然后将其设置为 1,但它也不起作用。

4

2 回答 2

1

您可以使用 GUI 删除外键。在表文件夹的 Management Studio 中,您可以在 Key 文件夹中找到外键。或用于EXEC sp_fkeys 'Your Table'查找外键的名称。

于 2015-11-28T19:49:04.513 回答
0

事实上,我想我终于成功了。我右键单击我的特定数据库并选择“设计”,然后在属性下的下拉菜单中找到外键的名称。这样我就能够找到程序设置的外键的名称,并正常删除它们。工作正常,数据库已清理。非常感谢您的建议!

于 2015-11-29T19:11:52.747 回答