外键及其约束理解

article/2025/9/29 9:40:50

一:首先是外键的定义

       如果一个字段X在一张表(表一)中是主关键字,而在另外一张表(表二)中不是主关键字则字段X称为表二的外键;换句话说如果关系模式R1中的某属性集不是自己的主键,而是关系模式R2的主键,则该属性集称为是关系模式R1的外键

二:主键表和外键表的理解

(1)以公共关键字作主键的表为主键表(父表,主表)

(2)以公共关键字作外键的表为外键表(从表,外表)


举个例子:

这里有2张表(student和depart)学生表和院系表,这里的字段departNum就是学生表的外键,这里的外键表是学生表,主键表是院系表。


四:外键的作用

各种书籍和网上的资料大多都是抽象空洞的解释:保证数据的完整性和一致性。

个人对此的理解与接下来的外键约束一起讲

五:外键约束

Mysql 下,外键设置:

on delete  规则:

1、CASCADE:级联

   (1)所谓的级联删除,就是删除主键表的同时,外键表同时删除。

   (2)以上面的例子将就是,假如院系表中的某个院系被删除了,那么在学生表中要想查询这个被删除的院系号所对应的院信息就会报错,因为已经不存在这个系了,所以,删除院系表(主键表)时必须删除其他与之关联的表,这里就说明了外键的作用,保持数据的一致性、完整性。当然反过来讲,你删除学生表中的记录,并不影响院系表中的数据,你查询院系号也能正确查询。所以删除外键表中的数据并不影响主键表。


2、NO ACTION(非活动,默认)、RESTRICT:约束/限制
  当取值为No Action或者Restrict时,则当在主键表中删除对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除。(即外键表约束主键表)
3、SET NULL
    当取值为Set Null时,则当在主键表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(,一样是外键表约束主键表,不过这就要求该外键允许取null)。

NO ACTION和RESTRICT的区别:只有在及个别的情况下会导致区别,前者是在其他约束的动作之后执行,后者具有最高的优先权执行。

六.实际应用

对象模型中的数据如下:

package org.model;public class Student {
private String stuNum;
private String stuName;
<span style="color:#FF0000;">private Depart depart;</span>
public String getStuNum() {return stuNum;
}
public String getStuName() {return stuName;
}
public Depart getDepart() {return depart;
}
public void setStuNum(String stuNum) {this.stuNum = stuNum;
}
public void setStuName(String stuName) {this.stuName = stuName;
}
public void setDepart(Depart depart) {this.depart = depart;
}}
这里设计对象模型时的属性并不是设计成departNum这个外键,而是整个Depart对象,这样做的好处是在查询时,就不用通过外键或者连接查询再多查询一次

若要通过外键查询:

<span style="font-size:18px;"> Query query=session.createQuery("from Student as stud where <span style="color:#FF0000;">stud.depart.departNum=:num</span>");query.setString("num","890");</span>



http://chatgpt.dhexx.cn/article/4x5fREmM.shtml

相关文章

Oracle 如何设置外键约束

表中的外键就是对于该属性所对应的域的限制&#xff0c;对于插入到表中的该属性的数据进行约束。并且该外键映射于所对应的另一张表的能唯一标识每一条数据的主键&#xff0c;根据参照完整性规则&#xff0c;外键可以取空值或者取对应主键的数值。外键的作用可以认为使两张表产…

外键约束详解及术语释疑

外键约束详解及术语释疑 先要理清几个概念&#xff1a; 1&#xff09;候选键&#xff08;Candidate Key&#xff09;&#xff1a;关系中的一个属性组&#xff0c;其值能唯一标识一个元组&#xff0c;若从该属性组中去掉任何一个属性&#xff0c;它就不具有这一性质了&#xf…

mysql 添加外键约束

创建表时添加约束 create table table_name( id int primary key auto_increment, #设为主键且自动增长 name not null unique, #不为空且值唯一 sex default 男, #使用默认约束&#xff0c;默认性别为男 constraint 索引名 foreign key(外键列) references 主键表(主键列…

SQL 外键约束

-- 概念 外键用来让2张表的数据之间建立连接&#xff0c;从而保证数据的一致性和完整性。 添加外键 第一种&#xff1a;在建表时直接添加 CREATE TABLE 表名(字段名 数据类型.....[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表(主表列名)); 第二…

外键约束三种形式

外键有三种约束模式&#xff1a; district : 严格模式(默认的)&#xff0c;父表不能删除或更新一个已经被子表数据引用的记录。cascade : 级联模式&#xff0c;父表的操作&#xff0c;对应子表关联的数据也跟着操作。 set null &#xff1a; 置空模式&#xff0c;父表被操作之…

mysql外键约束

1、什么是外键 -- 约束 2、外键的作用 用于表与表之间的关联 3、外键的创建 3、1 mysql 创建带有外键的表 CREATE TABLE student (id int(4) NOT NULL AUTO_INCREMENT COMMENT 学号,name varchar(10) NOT NULL DEFAULT "匿名" COMMENT 姓名,password varchar(11) N…

数据库是否应该使用外键约束?

一、前言 对于【是否使用外键约束】这个话题已经是老生常谈的了。在学校中&#xff0c;老师交给我们的大多是需要我们建立外键约束&#xff0c;但进入了实际工作很多时候并不会使用外键&#xff0c;而是通过代码逻辑来控制。包括在阿里的JAVA规范中也明确规定&#xff1a;【强…

mysql 创建外键约束

前言 如果一张表中有一个非主键的字段指向了另一张表中的主键&#xff0c;就将该字段叫做 外键。 一张表中外键可以有多个&#xff0c;也就是不同字段指向了不同表中的主键。 方式1-在创建表时设置外键约束 [constraint <外键名>] foreign key 字段名 [&#xff0c;字段…

外键及外键约束理解

转自&#xff1a;https://www.cnblogs.com/chenxiaohei/p/6909318.html 数据库&#xff08;外键及其约束理解&#xff09; 一&#xff1a;首先是外键的定义 如果一个字段X在一张表&#xff08;表一&#xff09;中是主关键字&#xff0c;而在另外一张表&#xff08;表二&#…

MySQL的约束——外键约束

约束&#xff1a; MySQL的约束的概述&#xff1a; 概念&#xff1a; 约束是作用于表中字段上的规则&#xff0c;用于限制存储在表中的数据 目的&#xff1a; 保证数据库中数据的正确&#xff0c;有效和完整性 分类 1.非空约束 NOT NULL 限制该字段的数据不能为null2.唯一…

4、外键约束(FOREIGN KEY)

MySQL 外键约束&#xff08;FOREIGN KEY&#xff09;是表的一个特殊字段&#xff0c;经常与主键约束一起使用。对于两个具有关联关系的表而言&#xff0c;相关联字段中主键所在的表就是主表&#xff08;父表&#xff09;&#xff0c;外键所在的表就是从表&#xff08;子表&…

【表的完整性约束外键约束】

外键约束 今天跟大家聊聊这个外键约束&#xff0c;简单来说呢&#xff0c;就是&#xff0c;嗯&#xff0c;&#xff0c;关于两个表的操作。对&#xff0c;就是这样的&#xff0c;来跟我一起看看叭。 【1】什么是外键约束&#xff1f; 外键约束&#xff08;FOREIGN KEY&#xf…

MySQL外键约束详解

今天继续给大家介绍MySQL相关知识&#xff0c;本文主要内容是MySQL外键约束详解。 一、MySQL外键约束作用 外键约束&#xff08;Foreign Key&#xff09;即数据库中两个数据表之间的某个列建立的一种联系。这种联系通常是以实际场景中含义完全相同的字段所造成的。MySQL通过外…

【MySQL】外键约束

文章目录 &#xff08;一&#xff09;外键约束&#xff08;二&#xff09;外键约束的功能&#xff08;三&#xff09;学生表和班级表&#xff08;1&#xff09;练习&#xff08;2&#xff09;两个问题&#xff08;3&#xff09;解决方案&#xff08;4&#xff09;结果展示 &…

JavaWeb JSP内置对象之session对象

4、session对象 在WEB应用中&#xff0c;当一个客户首次访问服务器上的某个jsp页面时&#xff0c;jsp引擎&#xff08;比如TOMCAT&#xff09;将为这个客户创建一个session对象&#xff0c;当客户关闭浏览器离开之后&#xff0c;session对象被注销。 设置session的目的是为了服…

jsp内置对象之session对象

在WEB应用中&#xff0c;当一个客户首次访问服务器上的某个jsp页面时&#xff0c;jsp引擎&#xff08;比如TOMCAT&#xff09;将为这个客户创建一个session对象&#xff0c;当客户关闭浏览器离开之后&#xff0c;session对象被注销。 设置session的目的是为了服务器端识别客户。…

JAVA Web入门之JSP内置对象的解析及使用(超详细必看)

创作不易 觉得有帮助请点赞关注收藏~~ 概述&#xff1a;由于JSP使用java作为脚本语言 所以JSP具有强大的对象处理能力 并且可以动态创建web页面内容 但java语言在使用一个对象前 需要先实例化这个对象 为了简化开发 JSP提供了一些内置对象 用来实现JSP应用 在使用JSP内置对象…

JSP内置对象和四大作用域

一、JSP九大内置对象 名称 类型 含义 获取方式 request HttpSevletRequest 封装所有请求信息 方法参数 response HttpServletResponse 封装所有响应信息 方法参数 session HttpSession 封装所有会话信息 req.getSession() application ServletContext 所有信…

jsp内置对象的作用范围

内置对象的作用范围是指每个内置对象的某个实例在多长时间和多大的范围中有效&#xff0c;即在什么样的范围内可以有效地访问同一个对象实例。 在javax.servlet.jsp.PageContext的类中定义了4个常量来指定内置对象的作用范围&#xff1a;APPLICATION_SCOPE、SESSION_SCOPE、PAG…

JSP内置对象——application对象

在介绍appl ication 对象之前&#xff0c;先简单介绍一些Web 服务器的实现原理。 对于大部分浏览器而言&#xff0c;它通常负责完成三件事情&#xff1a; &#xff08;1&#xff09;向远程服务器发送请求。 &#xff08;2&#xff09;读取远程服务器返回的字符串数据。 &#x…