MySQL InnoDB CASCADE?

时间:2009-10-16 13:57:59

标签: sql foreign-keys innodb cascade

我开始尝试在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表都不受影响。

谁能看到我出错的地方?

任何建议表示赞赏。
感谢。

1 个答案:

答案 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部分;它也会从页面中删除。

工作得很好。

编辑 - 我输入了您的创建,它也可以正常工作。