[英]MySQL innodb foreign keys
Why will this sql not create the foreign key? 为什么此sql不创建外键?
DROP TABLE IF EXISTS `flow_people`;
CREATE TABLE `flow_people` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`active` enum('0','1') COLLATE utf8_unicode_ci DEFAULT '0',
`created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`token` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
`unixtime` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
`modified` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
`company_name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
`salutation` varchar(4) COLLATE utf8_unicode_ci DEFAULT NULL,
`first_name` varchar(20) COLLATE utf8_unicode_ci NOT NULL,
`middle_name` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`last_name` varchar(20) COLLATE utf8_unicode_ci NOT NULL,
`dob` date NOT NULL,
`cams` decimal(7,0) NOT NULL,
`location_id` int(8) NOT NULL,
`people_type` int(8) NOT NULL COMMENT 'flow_people_types',
`comment` longtext COLLATE utf8_unicode_ci,
PRIMARY KEY (`id`),
FOREIGN KEY (`people_type`) REFERENCES flow_people_types(`id`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=InnoDB AUTO_INCREMENT=1666 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
the table flow_people_types exists, it has an ID column. 该表flow_people_types存在,它具有一个ID列。
I think I am missing something fundamental here, what is the problem? 我想我在这里缺少基本的东西,这是什么问题?
Check this link MySQL Foreign Keys : 检查此链接MySQL外键 :
Try this: 尝试这个:
DROP TABLE IF EXISTS `flow_people`;
CREATE TABLE `flow_people` (
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`active` ENUM('0','1') COLLATE utf8_unicode_ci DEFAULT '0',
`created` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`token` VARCHAR(50) COLLATE utf8_unicode_ci DEFAULT NULL,
`unixtime` VARCHAR(50) COLLATE utf8_unicode_ci DEFAULT NULL,
`modified` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
`company_name` VARCHAR(255) COLLATE utf8_unicode_ci DEFAULT NULL,
`salutation` VARCHAR(4) COLLATE utf8_unicode_ci DEFAULT NULL,
`first_name` VARCHAR(20) COLLATE utf8_unicode_ci NOT NULL,
`middle_name` VARCHAR(20) COLLATE utf8_unicode_ci DEFAULT NULL,
`last_name` VARCHAR(20) COLLATE utf8_unicode_ci NOT NULL,
`dob` DATE NOT NULL,
`cams` DECIMAL(7,0) NOT NULL,
`location_id` INT(8) NOT NULL,
`people_type` INT(8) NOT NULL COMMENT 'flow_people_types',
`comment` LONGTEXT COLLATE utf8_unicode_ci,
PRIMARY KEY (`id`),
KEY `FK_flow_people_FPT` (`people_type`),
CONSTRAINT `FK_flow_people_FPT` FOREIGN KEY (`people_type`) REFERENCES flow_people_types(`id`) ON DELETE NO ACTION ON UPDATE NO ACTION
) ENGINE=INNODB AUTO_INCREMENT=1666 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.