*外键 foreign key*

    1、概念:如果一个实体的(student)的某个字段,指向(引用)另个实体(class)的主键
(class:class_id),就称为student实体的class_id是 外键 。

  【声名】被指向的实体,称之为主实体(主表),也叫父实体(父表)。class
      负责指向的实体,称之为从实体(从表),也叫子实体(子表)。student

      作用:用于约束处于关系内的实体。

         比如说:我们去一家很火的餐厅吃饭,去餐厅之前我们是在网上预约了位置的客户,与此同时也刚好来了另外一桌未预约的客户,当餐厅恰好空出一个用餐位置。此时餐厅应该先安排在预约名单中客户,而不是未预约的客户。这就是一种约束关系。(例子举得不太好,大佬们见谅哈)

两大限制:
1)增加子表记录时,是否有之对应的父表记录。如果有,则数据插入成功;否则,数据插入失败。
2)在删除或者更新主表记录时,从表应该如何处理相关的记录。

2、定义外键:

在从表上,增加一个 外键字段,指向主表的主键。使用关键字 foreign key

语法:foreign key ([从表]外键字段) 主表名 (关联字段)

3、例子解释

#表一:学生信息表(主表)

CREATE TABLE stu_info (
id int(10) primary key auto_increment,
name varchar(10) not null,
sex varchar(10),
birth varchar(15)) character set utf8;

#表二:学生成绩表(从表)

CREATE TABLE stu_marks (
id int(10) primary key auto_increment,
CHINESE int (3),
MATH int (3),
ENGLISH int (3),
foreign key (id) references stu_info (id)) character set utf8; #设置外键约束,foreign key ([从表]外键字段) 主表名 (关联字段)。

【解析】:

设置“外键约束”后的作用,相当于事先建立了一个库,当从表需要插入数据时只能插入 被约束的值,也就是 库 中已经存在的值。

比如我们这边的例子是设置 外键约束 是 id,所以我们在给从表 插入数据时就会有约束,从表 的id值必须是在 主表 中已经存在的,否则报错。

【报错例子】:

报错原因:

    我们给学生成绩表(从表)插入信息时,由于学生信息表(主表)中不存在 id=2016888888 的学生信息,所以插入信息失败。

4、删除操作:

    4.1 删除 ‘从表’ 中的数据:不会影响 主表 的数据

      例子:delete from stu_marks where id=2016030638;

        

   4.2删除 ‘主表’ 中的数据:

        例子:delete from stu_info where id=2015020314;

解析:由于开启了外键约束,会检查外键约束,所以我们无法“删除”或者“更新”主表 stu_info中的数据。

  4.2.3删除/更新 ‘主表’ 中的数据方法:

      1)关闭外键约束检查:set foreign_key_checks=0;

      

   4.2.4禁止删除/更新 ‘主表’ 中的数据:

       1)打开外键约束检查:set foreign_key_checks=1;

外键约束:foreign key的更多相关文章

  1. MySQL系列(十一)--外键约束foreign key的基本使用

    有些时候,为了保证数据的完整性,我们会选择的使用外键约束,例如教师对应的表和课程表中老师的id,这种时候就要使用外键约束了. PS:这里不考虑表结构设计,三范式与反范式等设计问题,基于MySQL8.0 ...

  2. 关于数据库主从表、主键PRIMARY KEY 外键约束 FOREIGN KEY 约束----NOT NULL,DEFAULT,CHECK

    如果由两个列共同组成主键,而且一个子表将主键作为可为空值的外键来继承,就可能得到错误的数据.可在一个外键列中插入有效的值,但在另一个外键列中插入空值.然后,可添加一个数据表检查约束,在可为空的外键中检 ...

  3. 外键约束 foreign key

    外键约束 :保持数据一致性,完整性实现一对多关系.外键必须关联到键上面去,一般情况是,关联到另一张表的主键 (因为一个表只存一类信息.用外键来做参照,保证数据的一致性,可以减少数据冗余) ##表acr ...

  4. mysql 外键(FOREIGN KEY)

    最近有开始做一个实验室管理系统,因为分了几个表进行存储·所以要维护表间的关联··研究了一下MySQL的外键. (1)只有InnoDB类型的表才可以使用外键,mysql默认是MyISAM,这种类型不支持 ...

  5. MySQL(10):实体、实体表和外键(foreign key)

    1.实体        数据库管理系统中的各种用于数据管理方便而设定的各种数据管理对象,如:数据库表.视图.存储过程等都是数据库实体.广义上讲,这些对象中所存储的数据也是数据库实体.因为它们也是确切存 ...

  6. SQL 语句外键 a foreign key constraint fails

    queryRunner.update("SET FOREIGN_KEY_CHECKS = 0;"); queryRunner.update(sql, pid); queryRunn ...

  7. 关系型数据库中主键(primary key)和外键(foreign key)的概念。

    刚接触关系型数据库的同学,会听过主键和外键的概念.这是关系型数据库的基本概念,需要清楚理解.今天我就以简洁的语言总结一下这个概念. 主键.一句话概括:一张表中,可以用于唯一标识一条记录的字段组(或者说 ...

  8. 数据库 SQL 外键约束 多表查询

    多表设计与多表查询 1.外键约束        表是用来保存现实生活中的数据的,而现实生活中数据和数据之间往往具有一定的关系,我们在使用表来存储数据时,可以明确的声明表和表之前的依赖关系,命令数据库来 ...

  9. 详解MariaDB数据库的外键约束

    1.什么是外键约束 外键约束(foreign key)就是表与表之间的某种约定的关系,由于这种关系的存在,我们能够让表与表之间的数据,更加的完整,关连性更强. 关于数据表的完整性和关连性,可以举个例子 ...

  10. 约束Constraints--主键约束、外键约束、唯一约束、检查约束、默认约束、NOT NULL约束、列约束与表约束、创建约束、删除约束

    约束   Including Constraints 以下内容转自:https://www.cnblogs.com/wcl2017/p/7043939.html和http://blog.csdn.ne ...

随机推荐

  1. (转)classload和class.forname()区别

    转自:http://carl-java.iteye.com/blog/978680 java中class.forName和classLoader都可用来对类进行加载.前者除了将类的.class文件加载 ...

  2. 解决Oracle ORA-01033: ORACLE initialization or shutdown in progress错误 和 ORA-01589错误 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项

    要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项 SQL> startupORACLE 例程已经启动. Total System Global Area  13533 ...

  3. VAR模型学习笔记

    目录 1 定义 VAR模型的具体步骤 建模步骤及公式 代码实现 1 定义 VAR模型除了分析自身滞后项的影响外,还分析其他相关因素的滞后项对未来值产生的影响参考 用来分析随机扰动对系统的动态冲击的大小 ...

  4. Markdown上手使用

    前言 学习Markdown主要是为了更好的编辑博客(捂脸),顺便学一学Markdown语法,毕竟MarkdownPad 2放着吃灰好久了(雾) MarkdownPad2 下载 链接:https://p ...

  5. 跨站点脚本攻击XSS

    来源:http://www.freebuf.com/articles/web/15188.html 跨站点脚本攻击是一种Web应用程序的攻击,攻击者尝试注入恶意脚本代码到受信任的网站上执行恶意操作.在 ...

  6. 大二组队(NABCD)

    (Need)需求 很多时候,外人都不了解我们的校园.为了宣传铁大.让更多人了解校园.走进铁大. (Approach)做法 我们有最基本的展示.对校园风貌有基本的讲解.有论坛供应大家讨论. (Benef ...

  7. (转载)设置虚拟机桥接模式以及解决桥接模式上不了网以及ping不通主机的问题

    解决问题的博客地址:设置虚拟机桥接模式以及解决桥接模式上不了网以及ping不通主机的问题 遇见的问题: 1.VMnet8无法设置为桥接模式 结论:只要主机网络可被桥接,VMnet8根本不需要设为桥接模 ...

  8. Elasticsearch系列---倒排索引原理与分词器

    概要 本篇主要讲解倒排索引的基本原理以及ES常用的几种分词器介绍. 倒排索引的建立过程 倒排索引是搜索引擎中常见的索引方法,用来存储在全文搜索下某个单词在一个文档中存储位置的映射.通过倒排索引,我们输 ...

  9. eclipse出错

    程序初次build project没有问题,代码没有做任何修改再次build project却出现了make[1]: ***这样的错误,这是为什么?尝试过修改一点代码后重新编译也可能出现make[1] ...

  10. 查看和设置mysql字符集

    http://218.194.248.2/~wuxiaogang/cpcourse/database/mysql/charset.htm 1. 修改mysql的my.cnf# vi /etc/my.c ...