我在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数据库的本地副本或类似的东西。
答案 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