错误1215:无法添加外键约束

时间:2013-07-16 16:59:25

标签: mysql mysql-workbench

我使用mySql Workbench构建了一个数据库,但是当我尝试将我的模型转发到服务器时,我收到以下错误:

  

错误:错误1215:无法添加外键约束

后面是定义外键的表的定义,salaire_annee_ca

我阅读了类似的主题,以确定导致此错误的常见原因,并检查:

  • 如果salaire_annee_ca中定义的外键引用了另一个表的主键,它就是
  • 如果代码中的某些内容允许我的密钥为空,而不是
  • 如果引用和外键的类型相同

在我看来,所有这些条件都没问题,所以我不明白为什么我仍然得到那个消息。以下是我的表格的定义:

这是两个主要的:


-- Table `credit_impot_db`.`salaires_annee`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `credit_impot_db`.`salaires_annee` (
  `salaire_annee_id` INT(11) NOT NULL ,
  `salaire_annuel` DOUBLE NOT NULL DEFAULT 0 ,
  `heures_travaillees` DOUBLE NOT NULL DEFAULT 0 ,
  `pourcentage_rsde` DOUBLE NOT NULL DEFAULT 0 ,
  `jours_travailles` INT(3) NOT NULL DEFAULT 0 ,
  PRIMARY KEY (`salaire_annee_id`) ,
  CONSTRAINT `salaire_annee_id`
    FOREIGN KEY (`salaire_annee_id` )
    REFERENCES `credit_impot_db`.`employes_ac` (`employe_ac_id` )
    ON DELETE CASCADE
    ON UPDATE CASCADE)
ENGINE = InnoDB;

This one is at the origin of the message :
-- -----------------------------------------------------
-- Table `credit_impot_db`.`salaire_annee_ca`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `credit_impot_db`.`salaire_annee_ca` (
  `salaire_annee_ca_id` INT(11) NOT NULL ,
  PRIMARY KEY (`salaire_annee_ca_id`) ,
  CONSTRAINT `salaire_annee_ca_id`
    FOREIGN KEY (`salaire_annee_ca_id` )
    REFERENCES `credit_impot_db`.`salaires_annee` (`salaire_annee_id` )
    ON DELETE CASCADE
    ON UPDATE CASCADE)
ENGINE = InnoDB;

还引用了以下两个:

-- -----------------------------------------------------
-- Table `credit_impot_db`.`employes`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `credit_impot_db`.`employes` (
  `employe_id` INT(11) NOT NULL AUTO_INCREMENT ,
  `employe_nom` VARCHAR(255) NOT NULL ,
  `employe_prenom` VARCHAR(255) NOT NULL ,
  `employe_fonction` VARCHAR(255) NULL ,
  `employe_experience` VARCHAR(255) NULL DEFAULT NULL ,
  PRIMARY KEY (`employe_id`) )
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `credit_impot_db`.`employes_ac`
-- -----------------------------------------------------
CREATE  TABLE IF NOT EXISTS `credit_impot_db`.`employes_ac` (
  `employe_ac_id` INT(11) NOT NULL AUTO_INCREMENT ,
  `fk_employe_ac_employe_id` INT(11) NULL ,
  `fk_employe_ac_ac_id` INT(11) NULL ,
  PRIMARY KEY (`employe_ac_id`) ,
  INDEX `fk_employe_ac_employe_id_idx` (`fk_employe_ac_employe_id` ASC) ,
  INDEX `fk_employe_ac_ac_id_idx` (`fk_employe_ac_ac_id` ASC) ,
  CONSTRAINT `fk_employe_ac_employe_id`
    FOREIGN KEY (`fk_employe_ac_employe_id` )
    REFERENCES `credit_impot_db`.`employes` (`employe_id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `fk_employe_ac_ac_id`
    FOREIGN KEY (`fk_employe_ac_ac_id` )
    REFERENCES `credit_impot_db`.`dossier_client` (`ac_id` )
    ON DELETE NO ACTION
    ON UPDATE NO ACTION)
ENGINE = InnoDB;

任何帮助将不胜感激!

4 个答案:

答案 0 :(得分:3)

我在使用Workbench时遇到了可怕的错误1215,并花了很长时间试图找出问题所在。我最终注意到我的一些表用“latin1 - default collat​​ion”定义,而其他表用“Schema Default”定义。我不得不在EER图中逐个扩展表定义,以查看更改此选项的选项。我将所有定义更改为“Schema Default”,问题就消失了。哇!

答案 1 :(得分:1)

好的,我想我明白了。这似乎是mySql Workbench的一个问题,如果出现错误消失:

  • 我首先在salaire_annee_ca
  • 中创建主键
  • 然后转发工程师我的数据库
  • 将我的主键声明为引用salaire_annee
  • 主键的外键
  • 再次转发我的数据库

答案 2 :(得分:1)

错误得到解决:

为像这样的表创建外键

CREATE TABLE users_so
  (
     username VARCHAR(10) NOT NULL,
     password VARCHAR(32) NOT NULL,
     enabled  SMALLINT,
     PRIMARY KEY (username)
  ); 

以下代码可以正常使用

 CREATE TABLE authorities_so
  (
     username  VARCHAR(10) NOT NULL,
     authority VARCHAR(10) NOT NULL,
     FOREIGN KEY (username) REFERENCES users_so(username)
  );  

答案 3 :(得分:0)

可能的原因之一可能是生产数据库上的默认存储引擎。

我的问题很相似。我还与Workbench合作,在本地工作得很好,在生产方面也很好,直到我使用Forward Engineering在生产服务器上重新创建模式。

其中一个表格变为MyISAM而不是InnoDb,而Row format中的Don't use变为Dynamic

我的解决方案是:

在Workbench中,

  • 检查需要外键的每个表InnoDb
  • Row formatDefault