有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

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

我在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秒

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


共 (3) 个答案

  1. # 1 楼答案

    imdb_id不是媒体表上的——外键必须引用键(或至少是唯一约束)。如果媒体表上的imdb_id应该是唯一的,那么您可以对其设置唯一约束,并可以使用外键引用它

    此外,在一个不能为null的列上设置了on delete null

  2. # 2 楼答案

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

    “id”是表“media”中的主键,而不是“imdb_id”。因此,您不能引用“imdb_id”

  3. # 3 楼答案

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

    ALTER TABLE media ADD CONSTRAINT cstr_imdb UNIQUE (imdb_id);