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数据库的本地副本或类似的东西
# 1 楼答案
imdb_id不是媒体表上的键——外键必须引用键(或至少是唯一约束)。如果媒体表上的imdb_id应该是唯一的,那么您可以对其设置唯一约束,并可以使用外键引用它
此外,在一个不能为null的列上设置了on delete null
# 2 楼答案
外键是关系数据库表中的一列或一组列,在两个表中的数据之间提供链接。它充当表之间的交叉引用,因为它引用另一个表的主键,从而在它们之间建立链接
“id”是表“media”中的主键,而不是“imdb_id”。因此,您不能引用“imdb_id”
# 3 楼答案
MySQL中的外键实际上不必引用主键列,但它必须引用唯一的列。因此,一种可能的修复方法是在
imdb_id
列上添加一个唯一的约束: