MySQL可以';t使用外键创建表

MySQL可以';t使用外键创建表,mysql,foreign-keys,Mysql,Foreign Keys,消息日志: 错误1005:无法创建表“assessmentbookdb.mcqs”(错误号:121) SQL语句: CREATE TABLE `assessmentbookdb`.`MCQs` ( `id` INT NOT NULL AUTO_INCREMENT , `MCQAnswer` VARCHAR(200) NOT NULL , `QuestionID` INT NOT NULL , PRIMARY KEY (`id`) , INDEX `QuestionID` (

消息日志:

错误1005:无法创建表“assessmentbookdb.mcqs”(错误号:121) SQL语句:

CREATE  TABLE `assessmentbookdb`.`MCQs` (
  `id` INT NOT NULL AUTO_INCREMENT ,
  `MCQAnswer` VARCHAR(200) NOT NULL ,
  `QuestionID` INT NOT NULL ,
  PRIMARY KEY (`id`) ,
  INDEX `QuestionID` (`QuestionID` ASC) ,
  CONSTRAINT `QuestionID`
    FOREIGN KEY (`QuestionID` )
    REFERENCES `assessmentbookdb`.`Question` (`QuestionID` )
    ON DELETE CASCADE
    ON UPDATE CASCADE)
ENGINE = InnoDB;
表创建失败,因为外键约束的格式不正确

不知何故,您的外键不正确。如果您所引用的表尚不存在,则可能出现这种情况。

请仔细检查:

  • 密钥的名称是唯一的
  • 您要耦合的两个键具有完全相同的数据类型(此处:
    INT NOT NULL
    ),甚至是有符号的
  • 引用字段实际上存在

基于谷歌搜索,我假设您有一个与您试图添加约束的名称相同的约束。可能是因为您没有从旧版本的表或其他内容中删除旧约束。

看一看,尽量不要给约束命名。

InnoDB支持外键(允许跨表交叉引用相关数据)和外键约束(有助于保持数据分布的一致性)。CREATE TABLE或ALTER TABLE语句中InnoDB外键约束定义的语法如下所示:

CREATE  TABLE `assessmentbookdb`.`MCQs` (
  `id` INT NOT NULL AUTO_INCREMENT ,
  `MCQAnswer` VARCHAR(200) NOT NULL ,
  `QuestionID` INT NOT NULL ,
  PRIMARY KEY (`id`) ,
  INDEX `QuestionID` (`QuestionID` ASC) ,
  CONSTRAINT `QuestionID`
    FOREIGN KEY (`QuestionID` )
    REFERENCES `assessmentbookdb`.`Question` (`QuestionID` )
    ON DELETE CASCADE
    ON UPDATE CASCADE)
    ENGINE = InnoDB

问题表已经存在,问题ID是问题表的主键。我找不到问题所在哦,是的,我有相同的名字。Thx a lotYet在另一个答案中,你写道“哦,是的,我有相同的约束名称。”-所以你没有检查它。正如这篇文章所建议的,确保它们是相同的signedess。我检查了完全相同的数据类型——都是bigint(20)——但一个是有符号的,另一个是无符号的。我也做了同样的,效果很好。
 [CONSTRAINT [symbol]] FOREIGN KEY
 [index_name] (index_col_name, ...)
REFERENCES tbl_name (index_col_name,...)
[ON DELETE reference_option]
[ON UPDATE reference_option]

 reference_option:
RESTRICT | CASCADE | SET NULL | NO ACTION