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

时间:2018-05-31 04:49:02

标签: java mysql hibernate rest

我在MySQL工作台上运行此查询,并在MacOS上安装了最新版本的MySQL。 我的SQL查询是:

CREATE DATABASE  IF NOT EXISTS `imdb`;
USE `imdb`;


DROP TABLE IF EXISTS `rating`;



DROP TABLE IF EXISTS `media`;

CREATE TABLE `media` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(70) DEFAULT NULL,
  `year` varchar(70) DEFAULT NULL,
  `rated` varchar(70) DEFAULT NULL,
  `released` varchar(70) DEFAULT NULL,
  `runtime` varchar(70) DEFAULT NULL,
  `genre` varchar(70) DEFAULT NULL,
  `director` varchar(70) DEFAULT NULL,
  `writer` varchar(70) DEFAULT NULL,
  `actors` varchar(70) DEFAULT NULL,
  `plot` varchar(7000) DEFAULT NULL,
  `language` varchar(70) DEFAULT NULL,
  `country` varchar(70) DEFAULT NULL,
  `awards` varchar(70) DEFAULT NULL,
  `poster` varchar(270) DEFAULT NULL,
  `metascore` varchar(70) DEFAULT NULL,
  `imdb_rating` varchar(70) DEFAULT NULL,
  `imdb_votes` varchar(70) DEFAULT NULL,
  `imdb_id` varchar(70) NOT NULL,
  `type` varchar(70) DEFAULT NULL,
  `dvd` varchar(70) DEFAULT NULL,
  `box_office` varchar(70) DEFAULT NULL,
  `production` varchar(70) DEFAULT NULL,
  `website` varchar(70) DEFAULT NULL,
  `response` varchar(70) DEFAULT NULL,
  PRIMARY KEY (`id`)

);

CREATE TABLE `rating` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `source` varchar(70) DEFAULT NULL,
  `value` varchar(70) DEFAULT NULL,
  `imdb_id` varchar(70) NOT NULL,

  PRIMARY KEY (`id`),
  FOREIGN KEY (`imdb_id`)
  REFERENCES `media`(`imdb_id`)
  ON DELETE SET NULL
);

SET FOREIGN_KEY_CHECKS = 1;

表评级的创建查询失败。我不知道为什么,任何帮助都会受到赞赏。

确切的错误回复是:

10:12:44
CREATE TABLE `rating` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `source` varchar(70) DEFAULT NULL,   `value` varchar(70) DEFAULT NULL,   `imdb_id` varchar(70) NOT NULL,    PRIMARY KEY (`id`),   FOREIGN KEY (`imdb_id`)   REFERENCES `media`(`imdb_id`)   ON DELETE SET NULL )

错误代码:1215。 无法添加外键约束
0.123秒

我正在构建一个Spring REST应用程序,它使用一个太多的关系来构建IMDB数据库的本地副本或类似的东西。

3 个答案:

答案 0 :(得分:2)

外键是关系数据库表中的一列或一组列,它提供两个表中数据之间的链接。它充当表之间的交叉引用,因为它引用了另一个表的主键,从而在它们之间建立了链接。

' ID'是您的表格中的主键'媒体'而不是' imdb_id'。因此,您无法引用< imdb_id'

答案 1 :(得分:2)

MySQL中的外键实际上不必引用主键列,但它必须引用唯一的列。因此,此处可能的一个解决方法是在imdb_id列上添加唯一约束:

ALTER TABLE media ADD CONSTRAINT cstr_imdb UNIQUE (imdb_id);

答案 2 :(得分:1)

imdb_id不是媒体表上的 - 外键必须引用键(或者至少是唯一约束)。如果媒体表上的imdb_id应该是唯一的,那么你可以在其上放置一个UNIQUE CONSTRAINT,并且能够用外键引用它。

此外,您对无法为空的列的删除设置为null