无法在mysql-workbench上添加外键约束

时间:2015-12-03 07:10:26

标签: mysql sql mysql-workbench

我正在尝试通过mysql workbench创建一个表。我收到以下错误: -

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

CREATE TABLE `propman`.`imageadassociation` (
  `ImageId` INT NOT NULL,
  `AdId` INT NOT NULL,
  INDEX `imageId_adassociation_idx` (`ImageId` ASC),
  INDEX `adId_adassociation_idx` (`AdId` ASC),
  CONSTRAINT `imageId_adassociation`
    FOREIGN KEY (`ImageId`)
    REFERENCES `propman`.`imagelocation` (`ImageId`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION,
  CONSTRAINT `adId_adassociation`
    FOREIGN KEY (`AdId`)
    REFERENCES `propman`.`advertisement` (`AdId`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION);

imageLocation表的创建状态语句如下: -

CREATE TABLE `imagelocation` (
  `ImageId` int(11) NOT NULL,
  `ImageLocationcol` varchar(200) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

广告表create语句如下: -

CREATE TABLE `advertisement` (
  `AdId` int(10) NOT NULL AUTO_INCREMENT,
  `PropertyId` int(10) NOT NULL,
  `AdTemplateId` int(10) NOT NULL,
  `ValidFrom` date DEFAULT NULL,
  `ValidTo` date DEFAULT NULL,
  PRIMARY KEY (`AdId`),
  KEY `AdTemplateId` (`AdTemplateId`),
  CONSTRAINT `advertisement_ibfk_2` FOREIGN KEY (`AdTemplateId`) REFERENCES `adtemplate` (`AdTemplateId`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

1 个答案:

答案 0 :(得分:2)

imageadassociation引用表。表imagelocationadvertisement引用的表。

引用中的2列需要满足条件:

来自Using Foreign Key Constraints上的Mysql手册页:

  

外键和引用键中的对应列必须   有类似的数据类型。整数类型的大小和符号必须是   相同。字符串类型的长度不必相同。对于   非二进制(字符)字符串列,字符集和排序规则   必须是一样的。

并且他们需要在引用的表中包含最左边的索引。这些条件不符合。 特别是imageId

上没有索引

显示宽度不重要(即:int(11))