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

Mysql 错误1215:无法添加外键约束,mysql,mysql-workbench,Mysql,Mysql Workbench,我使用mySql Workbench构建了一个数据库,但是当我尝试将我的模型转发到服务器时,我得到了以下错误: 错误:错误1215:无法添加外键约束 然后是定义外键的表的定义,salaire\u annee\u ca 我阅读了类似的主题以确定此错误的常见原因,并检查了: 如果salaire\u annee\u ca中定义的外键引用另一个表的主键,则它会引用另一个表的主键 如果代码中的某些内容允许我的密钥为null,而它不允许 如果引用和外键的类型相同 在我看来,所有这些条件都是好的,所以我不

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

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

然后是定义外键的表的定义,
salaire\u annee\u ca

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

  • 如果
    salaire\u annee\u ca
    中定义的外键引用另一个表的主键,则它会引用另一个表的主键
  • 如果代码中的某些内容允许我的密钥为null,而它不允许
  • 如果引用和外键的类型相同
在我看来,所有这些条件都是好的,所以我不明白为什么我仍然得到这个信息。以下是我的表格的定义:

这是两个主要问题:


以下两项也被引用:

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

任何帮助都将不胜感激

好吧,我想我已经明白了。mySql Workbench似乎有问题,如果出现以下情况,错误将消失:

  • 我首先在salaire\u annee\u ca中创建我的主键
  • 然后转发我的数据库
  • 将我的主键声明为引用salaire\u annee主键的外键
  • 再次转发我的数据库

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

我的问题也很相似。我也使用Workbench,并且在本地工作得很好,在生产环境中也很好,直到我使用Forward Engineering在生产服务器上重新创建模式

其中一个表变成
MyISAM
而不是
InnoDb
,并且
中的
行格式
不使用
变成
动态

我的解决办法是:

在Workbench中

  • 检查每个需要外键为InnoDb的表,并
  • 行格式
    默认值

错误得到解决:

为这样的表创建外键

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

我在使用工作台时遇到了可怕的错误1215,花了很长时间试图找出问题所在。我最终注意到,我的一些表是用“latin1-default排序规则”定义的,而其他表是用“Schema default”定义的。我必须在EER图中一个接一个地展开表定义,以查看更改此项的选项。我将所有的定义都更改为“schemadefault”,问题就消失了。哇

绝对奇怪,但它起作用了,谁知道为什么。
 CREATE TABLE authorities_so
  (
     username  VARCHAR(10) NOT NULL,
     authority VARCHAR(10) NOT NULL,
     FOREIGN KEY (username) REFERENCES users_so(username)
  );