我开始尝试在Web应用程序中使用InnoDB。我已经设置了一些带有外键的表,但它们没有按预期运行。 这是我的表CREATE语句:
CREATE TABLE sections (
section_id INT NOT NULL AUTO_INCREMENT,
title VARCHAR(30),
created_at int(10) NOT NULL,
updated_at int(10) NOT NULL,
PRIMARY KEY(section_id)
) ENGINE=InnoDB;
CREATE TABLE pages (
page_id INT NOT NULL AUTO_INCREMENT,
section_idfk INT NOT NULL,
PRIMARY KEY(page_id),
FOREIGN KEY(section_idfk) REFERENCES sections(section_id)
ON DELETE CASCADE
ON UPDATE CASCADE
) ENGINE=InnoDB;
这些表创建正常,我可以使用数据填充它们,但是,我希望我对Sections表所做的任何更改都会对Pages表中的相应行产生影响。我尝试更改部分的ID并完全删除部分。在这两种情况下,Pages表都不受影响。
谁能看到我出错的地方?
任何建议表示赞赏。
感谢。
答案 0 :(得分:2)
我在MySQL查询浏览器中快速组合了两个类似的表,其中包含以下定义:
DROP TABLE IF EXISTS `test`.`sections`;
CREATE TABLE `test`.`sections` (
`section_id` int(10) unsigned NOT NULL auto_increment,
`title` varchar(30) NOT NULL,
`created_at` int(10) unsigned NOT NULL,
`updated_at` int(10) unsigned NOT NULL,
PRIMARY KEY (`section_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
DROP TABLE IF EXISTS `test`.`pages`;
CREATE TABLE `test`.`pages` (
`page_id` int(10) unsigned NOT NULL auto_increment,
`section_idfk` int(10) unsigned NOT NULL,
PRIMARY KEY (`page_id`),
KEY `section_idfk` (`section_idfk`),
CONSTRAINT `section_idfk` FOREIGN KEY (`section_idfk`) REFERENCES `sections` (`section_id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
与您发布的不完全相同,但足够接近。
我插入一行。 我在pages表中添加了一个匹配section_id的行。 然后我做一个DELETE FROM部分;它也会从页面中删除。
工作得很好。
编辑 - 我输入了您的创建,它也可以正常工作。