mysql - 错误 1215 : Cannot add foreign key constraint

标签 mysql mysql-workbench

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

ERROR: Error 1215: Cannot add foreign key constraint

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

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

  • 如果 salaire_annee_ca 中定义的外键引用了另一个表的主键,则确实如此
  • 如果代码中的某些内容允许我的 key 为空,但事实并非如此
  • 如果引用类型和外键类型相同

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

这是两个主要的:


-- 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;

如有任何帮助,我们将不胜感激!

最佳答案

我在使用工作台时遇到了可怕的错误 1215,并花了很长时间试图找出问题所在。我最终注意到我的一些表是用“latin1 - 默认排序规则”定义的,而其他表是用“模式默认”定义的。我必须在 EER 图中一一展开表定义才能看到更改此设置的选项。我将所有定义更改为“架构默认”,问题就消失了。哇!

关于mysql - 错误 1215 : Cannot add foreign key constraint,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17682654/

相关文章:

php - PDO 选择倍数 count()

php - 如何用php将xml插入mysql

mysql - 从 MySQL 客户端通过 AWS 堡垒主机连接到 MySQL RDS 实例

MySql 工作台 : Log file path must be defined before calling the WriteToLog method error

javascript - Nodejs mysql 中的动态下拉列表

php - UPDATE LOW_PRIORITY 它是否返回正确数量的受影响行?

mysql - 具有非二进制文件格式的数据库建模软件?

mysql - 使用 MySQL : Display all of the Column_Name in upper case, 按字母顺序排序,不重复

Mysql调用过程在动态更改其中的表时失败

mysql - 无法对特定记录运行查询