繁体   English   中英

MySQL无法使用外键创建表

[英]MySQL can't create table with foreign key

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;

消息日志:

错误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 ),甚至有符号
  • 引用字段实际存在

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

表创建失败,因为未正确形成外键约束

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

在这里看看,并尝试不给您的约束起一个名字。

http://dev.mysql.com/doc/refman/5.5/en/innodb-foreign-key-constraints.html

InnoDB支持外键和外键约束,这些外键使您可以跨表交叉引用相关数据,外键约束可以使这些扩展数据保持一致。 CREATE TABLE或ALTER TABLE语句中的InnoDB外键约束定义的语法如下所示:

 [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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM