MySQL外键与约束详解

需积分: 9 2 下载量 155 浏览量 更新于2024-07-20 收藏 639KB PPTX 举报
"MySQL.pptx 讲解了MySQL数据库中的外键约束、外键的添加方式、触发器以及索引的创建与作用。" 在MySQL数据库系统中,外键是一个重要的概念,它用于维护数据库表之间的引用完整性,确保数据的一致性。外键是一种特殊的列,它的值必须是另一个表(主表)中的主键的值或其允许的NULL值。在外键总结中,我们可以看到以下几个关键点: 1. **外键默认约束类型**: 默认情况下,外键约束类型是`RESTRICT`(或`NOACTION`),这意味着在执行删除或更新操作时,如果会影响到子表中的关联数据,操作将会被阻止。 - 主键关联列:不能直接删除或更新。 - 子表外键关联字段:不能更新,也不能插入非关联的主键值。 - 删除操作:子表中关联字段可以自由删除,但父表中的主键关联字段不能删除。 2. **数据一致性完整性**:当主表和子表之间的主外键列数据不一致时,尝试建立外键连接会失败。因此,确保数据的一致性是创建外键的前提。 3. **添加外键**:可以通过两种方式添加外键: - 修改表结构添加:`ALTER TABLE yourtablename ADD [CONSTRAINT 外键名] FOREIGN KEY [id](index_col_name,) REFERENCES tbl_name(index_col_name,) [ON DELETE {CASCADE|SETNULL|NOACTION|RESTRICT}][ON UPDATE {CASCADE|SETNULL|NOACTION|RESTRICT}]` - 创建表时添加:`CREATE TABLE infos (Name char(10) REFERENCES students(Name), ...)` 4. **ON DELETE 和 ON UPDATE 触发动作**: - `CASCADE`: 父表上的删除或更新操作会同步到子表,删除或更新对应的记录。 - `SETNULL`: 如果设置为`SETNULL`,父表记录被删除或更新时,子表相关列的值会被设置为NULL。但这要求子表的外键列允许为NULL。 5. **触发器与外键**:在定义触发器时,需要注意它可能会影响外键约束的执行,因此必须谨慎处理。 6. **索引的创建与作用**:`CREATE INDEX`语句用于创建索引,提高查询效率。索引虽不可见,但对查询性能至关重要。 - 语法:`CREATE INDEX index_name ON table_name (col_name);` - 更新包含索引的列会相对较慢,因为索引需要同步更新。因此,应在经常被搜索的列上创建索引,以优化查询性能。 这个资源提供了关于MySQL中外键约束的详细解释,包括它们如何工作、如何添加以及与触发器和索引的关系,这对于理解和维护复杂的数据库结构非常有用。理解并熟练运用这些概念可以有效提升数据库管理的效率和数据的准确性。