mysql - 如何在 mysql 中使用删除级联?

标签 mysql sql foreign-keys cascade

我有一个组件数据库。每个组件都属于特定类型。这意味着组件和类型之间存在多对一的关系。当我删除一个类型时,我想删除所有具有该类型外键的组件。但是如果我没记错的话,级联删除会在删除组件时删除类型。有什么办法可以做到我描述的吗?

最佳答案

这是您要包含在组件表中的内容。

CREATE TABLE `components` (
    `id` int(10) unsigned NOT NULL auto_increment,
    `typeId` int(10) unsigned NOT NULL,
    `moreInfo` VARCHAR(32), 
    -- etc
    PRIMARY KEY (`id`),
    KEY `type` (`typeId`)
    CONSTRAINT `myForeignKey` FOREIGN KEY (`typeId`)
      REFERENCES `types` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
)

请记住,您需要使用 InnoDB 存储引擎:默认的 MyISAM 存储引擎不支持外键。

关于mysql - 如何在 mysql 中使用删除级联?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/511361/

相关文章:

php - UTF-8贯穿始终

sql - '(' 附近的语法不正确。期待身份证件

mysql - 将 MySQL 迁移到 SQL Server - 外键给出了一个不清楚的错误(对我来说)

sql - 查询不适用于外键作为另一个表 Oracle SQL 的复合主键

mysql - mySQL 不能在表之间共享外键吗?

MySQL Where查询使用带有特殊字符的字符串

mysql - 帮助复杂的mysql查询

php - 如何处理 PHP+MySQL 中的 UTF-8 与 Latin-1 编码问题

mysql - 需要 SQL 专家来处理复杂的查询

SQL Server - 查询运行时已将多少行插入到表中?