`
geelong
  • 浏览: 120634 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

外键约束

阅读更多

总结:
1、父表类型 innodB
2、子表在外键的字段上建立索引 index


create database test;
use demo;


user表:
create table user
(
userid integer not null auto_increment primary key,
username varchar(12) not null
)
type=innodb;



主要是在建password表的时候,对userid列要加 index,即:
create table password
(
userid integer not null,
password varchar(12) not null,
index (userid),
foreign key (userid) references user (userid)
on delete cascade
on update cascade
);


在user表中插进一些数据:
userid  username
1        jimy
2        tom
3        jean
在password 表中插进一些数据:
userid  password
1        jimypass
2        tompass
3        jeanpass

insert into user (username) values ('jimy');
insert into user (username) values ('tom');
insert into user (username) values ('jean');


insert into password (password) values ('jimypass');
//这样的语句是错误的

外键关联式用于由于外键参考的主键的元素改变时,外键元素也做相应改变
在增加数据的时候要把外键参考主键的值输进去,外键才能和相应的主表行建立起关系


insert into password (userid,password) values (1,'jimypass');

在user表中删除 jimy,它的password记录也应该被“级联删除”,
delete from user where username='jimy';
//成功,结果在password表中也被删除


除了 CASCADE 外,还有 RESTRICT(禁止主表变更)、SET NULL(子表相应字段设置为空)等操作。

InnoDB拒绝任何试着在子表创建一个外键值而不匹配在父表中的候选键值的INSERT或UPDATE操作。一个父表有一些匹配的行的子表,InnoDB对任何试图更新或删除该父表中候选键值的UPDATE或DELETE操作有所动作,这个动作取决于用FOREIGN KEY子句的ON UPDATE和ON DETETE子句指定的referential action。当用户试图从一个父表删除或更新一行之时,且在子表中有一个或多个匹配的行,InnoDB根据要采取的动作有五个选择:
· CASCADE: 从父表删除或更新且自动删除或更新子表中匹配的行。ON DELETE CASCADE和ON UPDATE CASCADE都可用。在两个表之间,你不应定义若干在父表或子表中的同一列采取动作的ON UPDATE CASCADE子句。
· SET NULL: 从父表删除或更新行,并设置子表中的外键列为NULL。如果外键列没有指定NOT NULL限定词,这就是唯一合法的。ON DELETE SET NULL和ON UPDATE SET NULL子句被支持。
· NO ACTION: 在ANSI SQL-92标准中,NO ACTION意味这不采取动作,就是如果有一个相关的外键值在被参考的表里,删除或更新主要键值的企图不被允许进行(Gruber, 掌握SQL, 2000:181)。 InnoDB拒绝对父表的删除或更新操作。
· RESTRICT: 拒绝对父表的删除或更新操作。NO ACTION和RESTRICT都一样,删除ON DELETE或ON UPDATE子句。(一些数据库系统有延期检查,并且NO ACTION是一个延期检查。在MySQL中,外键约束是被立即检查的,所以NO ACTION和RESTRICT是同样的)。

· SET DEFAULT: 这个动作被解析程序识别,但InnoDB拒绝包含ON DELETE SET DEFAULT或ON UPDATE SET DEFAULT子句的表定义。



no action 实验


user表:
create table user
(
userid integer not null auto_increment primary key,
username varchar(12) not null
)
type=innodb;



主要是在建password表的时候,对userid列要加 index,即:
create table password
(
userid integer not null,
password varchar(12) not null,
index (userid),
foreign key (userid) references user (userid)
on delete no action
on update no action               //no action 有空格  级联关系写在子表
);

insert into user (username) values ('jimy');
insert into user (username) values ('tom');
insert into user (username) values ('jean');


insert into password (userid,password) values (1,'jimypass');  //先有外键参考的列值,才能插入

delete from user where username='jimy';
//删除失败
 ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constrai
nt fails (`test/password`, CONSTRAINT `password_ibfk_1` FOREIGN KEY (`userid`) R
EFERENCES `user` (`userid`) ON DELETE NO ACTION ON UPDATE NO ACTION)

delete from password where userid=1;
delete from user where username='jimy';
//删除成功

总结:在子类中有参考父类键值时,父类行的更新和删除都将失败

分享到:
评论

相关推荐

    mysql数据库触发器,外键约束模式知识点

    ### MySQL 数据库触发器与外键约束模式知识点详解 #### 一、外键约束机制 在MySQL数据库中,外键约束是一种确保数据完整性的方法,它通过定义表间关系来维护数据的一致性。 ##### 1.1 增加外键 外键可以在创建表...

    禁用启用所有外键约束.tst

    在数据库管理中,外键约束是关系数据库设计中的一个重要概念,用于维护数据的一致性和完整性。外键约束确保了引用的完整性,即一个表中的外键值必须是另一个表中存在的主键值。在进行大规模数据导入、更新或者调试时...

    MySQL删除表的时候忽略外键约束的简单实现

    在MySQL数据库管理中,删除表是一项需要谨慎操作的任务,尤其是当表之间存在外键约束时。外键约束是关系数据库中确保数据完整性和一致性的重要机制,它不允许在父表(引用其他表的字段的表)中删除那些已被子表引用...

    数据库下所有表的外键约束查询

    用于查询某个数据库下所有表的外键约束情况,以便统一分析外键约束是否合理;主要查询出外键的,是否级联删除,级联更新,强制外键约束,强制复制约束始终状态。如想使用别的状态,请自行添加。下载的童鞋别下载错了...

    数据库表排序,主表子表放置外键约束

    "数据库表排序,主表子表放置外键约束"这一主题涉及到数据库规范化、外键约束、数据导入以及程序化解决方案。下面将详细阐述这些知识点。 首先,**外键约束**是关系数据库中的一种机制,用于确保一个表(子表)中的...

    Oracle定义约束 外键约束

    ### Oracle定义约束:外键约束详解 #### 一、引言 在数据库设计与管理过程中,维护数据的一致性和完整性是非常重要的。Oracle数据库系统提供了一系列的机制来帮助开发者和管理员达到这一目标,其中最重要的机制之一...

    自动删除所有表,有外键约束的表优先删除

    标题"自动删除所有表,有外键约束的表优先删除"涉及到的是一个数据库操作的场景,通常需要谨慎处理,因为错误的操作可能导致数据丢失或破坏数据库结构。在这个问题中,我们关注的是如何在有外键约束的环境中安全地...

    sql外键约束

    在SQL(结构化查询语言)中,外键约束是一种重要的关系数据库完整性机制,它用于确保数据的一致性和准确性。外键约束是两个表之间的一种关联,一个表中的外键引用了另一个表的主键,从而建立了两个表之间的联系。...

    用触发器实现SQLite的外键约束

    ### 使用触发器实现SQLite的外键约束 #### 背景与问题介绍 在进行数码相框嵌入式开发的过程中,开发团队选择了SQLite作为数据库管理系统。然而,在编码过程中遇到了一个较为棘手的问题:SQLite默认情况下不支持...

    数据库外键约束的作用与实现

    数据库外键约束是关系型数据库管理系统中的一种机制,旨在保持不同表之间数据的一致性和完整性。其核心作用包括维护数据一致性、确保引用完整性、支持级联操作以及简化数据操作。 首先,维护数据一致性是外键约束的...

    禁用、启用外键约束和触发器

    ### 禁用、启用外键约束和触发器:深入解析与实践 #### 一、基础知识:外键约束与触发器 **外键约束(Foreign Key Constraint)**是数据库设计中用于确保数据完整性的关键机制之一。它通过定义一个表(子表)中的...

    数据库外键约束方式

    数据库外键约束方式 外键约束是数据库中实现参照完整性的重要手段,它能够确保数据的一致性和正确性。外键约束方式有多种,包括级联、置空和禁止三种方式。 级联(Cascade)方式是指当主表中的记录被删除或更新时...

    MySQL的约束-外键约束

    本文将深入探讨其中的一种约束类型——外键约束(Foreign Key Constraint),它是关系数据库模型中的核心概念,用于建立和维护不同表之间的关联。 外键约束允许一个表中的数据引用另一个表中的数据,这种引用关系...

    数据库技术与应用 外键约束-A学习任务书.doc

    在数据库技术中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性。外键约束是关系数据库设计中的一个关键元素,特别是在实施参照完整性的场景下。本学习任务书将带你深入理解和掌握外键约束的应用。 ...

    MySQL外键约束常见操作方法示例【查看、添加、修改、删除】

    在MySQL数据库中,外键约束是关系型数据库中用于维护数据完整性和一致性的重要工具。它确保了一张表中的数据与另一张表的数据之间的关联性,通常用于实现一对一、一对多或多对多的关系。本篇文章将详细讲解如何进行...

    MySQL数据库中的外键约束详解.doc

    在数据库管理中,外键约束是确保数据一致性、完整性和参照完整性的核心机制之一。在MySQL数据库中,特别是在处理关系型数据表时,外键扮演着关键角色。本文档详细介绍了MySQL数据库中外键约束的概念、应用和相关操作...

    MLDN魔乐科技_Oracle课堂18_外键约束

    在数据库设计中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性。本课程"MLDN魔乐科技_Oracle课堂18_外键约束"深入讲解了Oracle数据库中如何利用外键来实现关系间的引用完整性。下面将详细阐述外键...

    数据一致性守护者:MySQL外键约束深度解析

    ### 数据一致性守护者:MySQL 外键约束深度解析 #### 引言 在现代软件开发中,特别是Web应用程序领域,数据库扮演着极其重要的角色。其中MySQL作为一种流行的关系型数据库管理系统(RDBMS),因其开放源代码特性、...

    MLDN魔乐科技JAVA培训_Oracle课堂18_外键约束.rar

    在数据库设计中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性。外键(Foreign Key)是数据库关系之间的一种链接,允许在一个表中的数据引用另一个表中的数据,形成表之间的关联。在本MLDN魔乐科技...

    数据库技术与应用 设置学生表外键约束-A学习任务书.doc

    在数据库技术中,外键约束是关系数据库设计中不可或缺的一部分,它主要用于确保数据的一致性和完整性。本学习任务书将重点讲解如何在学生表中设置外键约束,以实现不同表之间的关联,这对于电子信息工程技术专业的...

Global site tag (gtag.js) - Google Analytics