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

ALTER TABLE `tbl_magazine_issue` 
DROP CONSTRAINT `FK_tbl_magazine_issue_mst_users`

但是我得到了一个错误:

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


当前回答

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

其他回答

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

ALTER TABLE tbl_magazine_issue
  DROP FOREIGN KEY FK_tbl_magazine_issue_mst_users

在MySQL中,你必须指定你想要删除的约束类型:

例子:

  CONSTRAINT `shop_ibfk_1` FOREIGN KEY (`fb_user_id`) REFERENCES `fb_user` (`id`),
  CONSTRAINT `shop_chk_1` CHECK ((`import_lock` in (0,1)))

第一个你可以用:

alter mytable shop drop FOREIGN KEY `shop_ibfk_1`;

第二个是

alter mytable drop CHECK `shop_chk_1`;

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

这将在MySQL上工作以删除约束

alter table tablename drop primary key;

alter table tablename drop foreign key;

对于那些使用MariaDB来这里的人:

注意,MariaDB通常允许DROP约束语句,例如删除检查约束:

ALTER TABLE table_name
DROP CONSTRAINT constraint_name;

https://mariadb.com/kb/en/library/alter-table/