我得到这个错误消息:
第40行的错误1217(23000) : 不能 删除或更新父行: 外键约束失败
当我试图摔桌子的时候:
DROP TABLE IF EXISTS `area`;
定义如下:
CREATE TABLE `area` (
`area_id` char(3) COLLATE utf8_spanish_ci NOT NULL,
`nombre_area` varchar(30) COLLATE utf8_spanish_ci NOT NULL,
`descripcion_area` varchar(100) COLLATE utf8_spanish_ci NOT NULL,
PRIMARY KEY (`area_id`),
UNIQUE KEY `nombre_area_UNIQUE` (`nombre_area`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_spanish_ci;
有趣的是,模式中的 我已经把其他桌子都弄掉了具有针对 area
的外键。实际上,除了 area
表之外,数据库是空的。
如果数据库中没有任何其他对象,它怎么可能有子行?据我所知,InnoDB 不允许在其他模式上使用外键,对吗?
(我甚至可以运行 RENAME TABLE area TO something_else
命令:-?)