Oracle 如何设置外键约束

article/2025/9/29 9:58:26

        表中的外键就是对于该属性所对应的域的限制,对于插入到表中的该属性的数据进行约束。并且该外键映射于所对应的另一张表的能唯一标识每一条数据的主键,根据参照完整性规则,外键可以取空值或者取对应主键的数值。外键的作用可以认为使两张表产生一定的关系。下面介绍如何设置外键约束

        1.创建表时就设置外键约束。

        为了插入数据不规范报错能够更快的找到错误的地方,外键一般都会设置一个别名来表示外键约束。外键所引用的另一个表的属性要是主键。

        我们可以直接在创建表时,声明属性的右边像写主键,unique, not null 约束一样设置外键约束。 这个时候就不用写入foreign key来表示该约束是外键约束。

格式为

create table xxx(

        属性名 属性类型 constraint 外键名 references 主键表 (主键名)

);

        下面我们来演示一下,有一个student表,里面有pid是主键表示学生的学号,pname是学生名字。另一个表是s_course表用来表示学生所选的课程,其中pid表示学生的学号对应于student表中的pid 就是该表的外键,另一个cname就是表示课程名。

        


--学生表
create table student(pid varchar2(10) primary key,pname varchar2(10));
--学生选择课程
create table s_course(pid varchar(10) constraint FK_pid references student(pid),cname varchar(20)
);

        我们对其两个表插入数据

insert into student values('A001','我');
insert into s_course value ('A001','数据库概述');

        发现上述的sql语句是可以执行成功的。

        但当我们插入课程表时,插入的学号不是空且学生表中学号没有的值时,就会报错。

insert into s_course values('A002','软件工程');

        另一个在表中设置约束的方法就是等表中所有属性全部声明完后,将外键约束写在表中的最后面,这个时候就需要指明foreign key 了。

        格式为:

        create table xxx(

                .....    ,

                constraint 外键名 foreign key (外键属性) references 主键表(主键名) 

        );

         也来演示一下效果,像上述的student表和s_course表我们对其进行修改。

        

drop table student;
drop table s_course;
--学生表
create table student(pid varchar2(10) primary key,pname varchar2(10));--学生选择课程
create table s_course(pid varchar(10) ,cname varchar(20),constraint FK_pid foreign key (pid) references student(pid) 
);

        插入数据也没有问题。

insert into student values('A001','我');
insert into s_course values ('A001','数据库概述');

        2.在表外设置外键约束。

        当我们创建了表之后,发现需要有一个外键约束,在不重新建表的前提下我们就可以通过alter语句来增加该属性的约束条件。外键也是约束。

        格式为:

        alter table 外键表名 add constraint 外键名 foreign key (外键表外键属性名) references 主键表名(主键名)

        下面进行演示一下效果,该例子也是用到了上述的student表和s_course表。

         

drop table student;
drop table s_course;
--学生表
create table student(pid varchar2(10) primary key,pname varchar2(10));
--学生选择课程
create table s_course(pid varchar(10),cname varchar(20)
);alter table s_course add constraint FK_pid foreign key (pid ) references student(pid);

        插入数据测试也是可以通过的。

insert into student values('A001','我');
insert into s_course values ('A001','数据库概述');


http://chatgpt.dhexx.cn/article/VLF5aldp.shtml

相关文章

外键约束详解及术语释疑

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

mysql 添加外键约束

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

SQL 外键约束

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

外键约束三种形式

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

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…

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

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

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…

JSP入门之JSP内置对象

系列文章目录 目录 前言 一、request对象 1.获取用户提交的信息 2.JSP页面文件的编码方式 3.常用方法举例 4.处理HTML标记 5.处理超链接 二、response对象 1.动态响应contentType属性 2.response对象的HTTP文件头 3.response对象的重定向 三、session对象 1.se…