我想从表中移除约束条件。我的问题是:

ALTER TABLE `tbl_magazine_issue` 
DROP CONSTRAINT `FK_tbl_magazine_issue_mst_users`

但是我得到了一个错误:

#1064 -你的SQL语法错误;请查看MySQL服务器版本对应的手册,在第一行使用“constraint FK_tbl_magazine_issue_mst_users”附近的正确语法


当前回答

我也遇到过同样的问题,我用下面的代码来解决:

ALTER TABLE `table_name` DROP FOREIGN KEY `id_name_fk`;
ALTER TABLE `table_name` DROP INDEX  `id_name_fk`;

其他回答

进入表的结构视图 您将在顶部a.表结构b.关系视图中看到2个选项。 现在单击关系视图,在这里可以删除外键约束。在这里你会得到所有的关系。

Mysql有一个特殊的语法来删除外键约束:

ALTER TABLE tbl_magazine_issue
  DROP FOREIGN KEY FK_tbl_magazine_issue_mst_users

为了给Robert Knight的答案补充一点,因为文章的标题本身没有提到外键(因为他的文章没有完整的代码示例,而且SO的注释代码块没有答案的代码块显示得那么好),我将为唯一的约束添加这个。这两种方法中的任何一种都可以去除约束:

ALTER TABLE `table_name` DROP KEY `uc_name`;

or

ALTER TABLE `table_name` DROP INDEX `uc_name`;

在MySQL中没有DROP约束。在你的情况下,你可以使用DROP外键代替。

我也遇到过同样的问题,我用下面的代码来解决:

ALTER TABLE `table_name` DROP FOREIGN KEY `id_name_fk`;
ALTER TABLE `table_name` DROP INDEX  `id_name_fk`;