当我执行下面的操作时,看起来它设置了常规KEY,而不是外键:
ALTER TABLE `dev1_IMGStoreTmpComponents`
ADD CONSTRAINT `con_fk_templates`
FOREIGN KEY `fk_templates`(`templateId`)
REFERENCES `dev1_IMGStoreTemplates`(`templateId`)
SQL成功运行。
然后我运行:
SHOW CREATE TABLE `dev1_IMGStoreTmpComponents`;
CREATE TABLE `dev1_IMGStoreTmpComponents` (
`componentId` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(100) COLLATE utf8mb4_unicode_520_ci NOT NULL,
`description` varchar(250) COLLATE utf8mb4_unicode_520_ci DEFAULT NULL,
`templateId` int(10) unsigned NOT NULL,
`type` char(3) COLLATE utf8mb4_unicode_520_ci NOT NULL,
`layer` tinyint(3) unsigned DEFAULT NULL,
`posx` mediumint(8) unsigned NOT NULL,
`posy` mediumint(8) unsigned NOT NULL,
`width` mediumint(8) unsigned NOT NULL,
`height` mediumint(8) unsigned NOT NULL,
`settings` text COLLATE utf8mb4_unicode_520_ci,
PRIMARY KEY (`componentId`),
UNIQUE KEY `componentId` (`componentId`,`templateId`),
KEY `con_fk_templates` (`templateId`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_520_ci COMMENT='Template Components'
为什么我在Create表中看不到CONSTRAINT?
答案 0 :(得分:1)
MyISAM存储引擎不支持外键约束。
ENGINE=MYISAM
InnoDB存储引擎支持参照完整性约束。 (需要使用InnoDB存储引擎定义引用表和引用表。)
ENGINE=INNODB
MySQL确实接受MyISAM表的外键约束语法,但MySQL忽略了外键。接受语法的最可能原因是使DDL从其他数据库迁移更容易。