首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法在mysql-workbench上添加外键约束。

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

Stack Overflow用户
提问于 2015-12-03 07:10:25
回答 1查看 946关注 0票数 1

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

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

代码语言:javascript
复制
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语句如下:

代码语言:javascript
复制
CREATE TABLE `imagelocation` (
  `ImageId` int(11) NOT NULL,
  `ImageLocationcol` varchar(200) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

广告表创建语句如下:

代码语言:javascript
复制
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;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-03 07:20:58

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

所引用的2列需要满足以下条件:

来自使用外键约束上的Mysql手册页面

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

而且它们需要在引用的表中有最左边的索引。这些条件没有得到满足。特别是,imageId上没有索引。

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34059826

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档