MySQL外键约束

MySQL外键约束

外键约束(FOREIGN KRY,缩写FK)是用来实现数据库表的参照完整性约束的。

外键约束可以是两张表紧密的结合起来,特别是针对修改或者删除的级联操作时,

会保证数据的完整性。

(注:级联(cascade)在计算机科学里指多个对象之间的映射关系,建立数据之间的级联关系提高管理效率)

外键是指表中某个字段的值依赖于另一张表中的某个字段的值,而被依赖的字段必须

具有主键约束或者唯一约束。被依赖的表我们通常称之为父表或者主表,设置外键约束的表

称之为子表或者从表。

举个栗子:

1、创建一个班级表

create table class (  cno int(4) auto_increment, cname varchar(12) not null,  room  varchar(4),   primary key(cno)  
);

2、插入数据

insert into class values (null,'java001',101);  
insert into class values (null,'java002',102);  
insert into class values (null,'java001',101); 

3、查询数据

4、创建一个学生表

create table student(  sno int(6) primary key auto_increment,  name varchar(12),  sex char(1),  age int(2),  classno int(4),  constraint fk_stu_classno foreign key (classno) references class(cno)  
);

5、查询表的结构

6、插入数据

insert into student values(null,'张三','男',23,1);  
insert into student values(null,'李四','男',24,1);  
insert into student values(null,'王五','男',16,2);  

7、查询student表数据

8、尝试删除、更改1班

delete from class where cno=1;update class set cno=5 where cno=2;

因为存在外键,class表中cno=1中有学生存在,所以删除不了。

如果想删除1班,请手动先对1班学生进行处理(删除或者清空外键)

 update student set classno=null where classno=1;

9、再次删除cno=1的班级

查询数据

10、修改外键设置:外键要修改只能先删除再添加

如果希望在更新班级号的时候,可以直接更新学生的班级编号;希望在删除某个班级的时候,清空学生的班级编号

(1)删除外键和添加外键

alter table student drop foreign key fk_stu_classno;

(2)修改外键设置

alter table student add constraint fk_stu_classno foreign key(classno) references class(cno) on delete set null on update cascade;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/562558.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

zookeeper 密码_Dubbo、ZooKeeper介绍

dubbo是一个分布式架构的服务框架,一般结合maven的模块式开发使用。传统的单架构项目,不方便维护和升级;通过maven的模块式开发,就可以把一个单架构的工程,拆封成一个一个的小模块,包括(jar和war)&#xff…

异常--java

java默认的异常处理机制 优点:发生异常后、会给出异常类型、异常提示信息、异常出现的位置 缺点:出现异常后,后续语句不执行了;提示信息太专业,可读性差 解决:try-catch-finally 处理异常;th…

192.168.8.1手机登陆_高端机型都在鼓吹的ufs3.1是什么?对于手机使感受明显吗?...

最近很多朋友留言问,ufs3.1是什么,很重要吗?下面就由小编来给大家介绍一下手机上的ufs3.1是什么!ufs是高端安卓手机,常用的储存协议,就好像我们电脑里的固态硬盘一样,速度越快,打开软…

使用try-catch-finally处理异常---java

package demo02;import java.util.Scanner;public class TestException {public static void main(String[] args) {Scanner input new Scanner(System.in);//输入总分try{System.out.println("请输入总分");int sum input.nextInt();System.out.println("请输…

代码合并工具_11个代码质量审核和管理工具,程序员必备!

「 读者福利!2 TB 各类技术资源免费赠送 」如今,代码质量分析和审核已成为每个企业的基本流程。随着开源代码库使用的增加,安全性和代码质量对于构建高质量软件至关重要。不良的代码不仅会影响代码的可维护性,而且还会在某些情况下…

异常体系----java

一、异常体系 1、error error类层次描述了java运行时系统内部错误和资源耗尽错误,一般指与jvm或动态加载等相关的问题, 如:虚拟机错误,动态链接失败,系统崩溃等。 2、exception 所有异常类的父类,其子…

xy坐标正负方向_【笛卡尔坐标系】

【壹】笛卡尔坐标系(Cartesian coordinates)就是直角坐标系和斜坐标系的统称。相交于原点的两条数轴,构成了平面放射坐标系。如两条数轴上的度量单位相等,则称此放射坐标系为笛卡尔坐标系。两条数轴互相垂直的笛卡尔坐标系,称为笛卡尔直角坐标…

throw和throws的使用

throw和throws的使用 public class Person {private String name;private int age;public Person(){}Person(String name,int age){this.name name;this.age age;}public int getAge() {return age;}public String getName() {return name;}public void setName(String name…

python解决最优化问题_python实现最优化算法

二分法函数详见rres,此代码使该算法运行了两次def asdf(x):rres8*x**3-2*x**2-7*x3return rresi2left0right1while i>0 :i i-1ans 0.1mid1 (left right ans) / 2mid2 (left right - ans) / 2aasdf(mid1)casdf(mid2)if a > c :right mid1else :left m…

为什么需要包装类?

1、某些方法的参数必须是对象,为了让基本数据类型的数据能作为参数,提供包装类。 2、包装类还可以提供更多的功能 3、其他特别重要的功能:比如可以实现字符串和基本数据类型之间的转换 认识一下包装类吧! package demo05;impor…

python自动计算多个教学班的优秀率_第二个月课堂009python之总结(002)

python7天的总结------------------------------------------------------------------------------------------------评价:1、函数 def 自定义行数和内建函数2、re模块3、python3和python的去别4、字典,元组,列表,元组&#xf…

一句话概括自动装箱/拆箱

自动装箱过程是通过调用包装类的valueOf()方法实现的,二自动拆箱过程是通过调用包装类的xxxValue()方法实现的(xxx代表对应的基本数据类型,如intValue,doubleValue等)。 …

python loop call soon_python3-asyncio 学习笔记 1 -- call_soon

最近在学习python3 的 asyncio, 特将学习笔记记录于此.先来个简单的例子:import asynciodef hello_world(loop):print(Hello World)loop.stop()loop asyncio.get_event_loop()# Schedule a call to hello_world()loop.call_soon(hello_world, loop)# Blocking call interrupte…

2021-05-24

String类的使用 package demo07;import java.util.Locale; import java.util.function.BiConsumer;public class TestString {public static void main(String[] args) {//1.创建一个String对象String str "abcDEfghijkL";//2.操作该String对象//2.1最简单的方法Sy…

StringBuffer和StringBuild

StringBuffer和StringBuild两个类的区别主要是: StringBuffer JDK1.0提供的类,线程安全,做线程同步检查,效率较低。 StringBuild JDK1.5提供的类,线程不安全,不做线程同步检查,因此效率较高。…

python背单词游戏_Python基础-背单词游戏

Hangman直译为“吊死鬼”,是一个猜单词的双人游戏。由一个玩家想出一个单词或短语,另一个玩家猜该单词或短语中的每一个字母。第一个人抽走单词或短语,只留下相应数量的空白与下划线。想字的玩家一般会画一个绞刑架,当猜字的玩家猜…

Date类练习

package demo09;import java.util.Date;public class TestDate {public static void main(String[] args) {//获取当前时间Date now new Date();//输出当前时间System.out.println(now.toString());System.out.println(now.toLocaleString());System.out.println(now.getYear(…

全连接层的作用_python构建计算图2——全连接层

(好久不更~)前文中,参照tensorflow的方式实现了简单的自动求导。接下来要在自动求导的基底(模板)上搭建简单的bp神经网络。计算图前文曾多次提到计算图,关于什么是计算图,有很多种说法。既然它被…

DateFormat类

DateFormat是一个抽象类,一般使用它的子类SimpleDateFormat类来实现。主要作用就是把时间队形转化成指定格式的字符串 反之,把指定格式的字符串转化成时间对象。 package demo10;import java.text.DateFormat; import java.text.ParseException; impor…

pythonocc 扩展数据_如何在pythonOCC中使用样条函数?

您只需将代码修改为C(而不是C)BOOST_PYTHON_MODULE(Spline){import_array();boost::python::numeric::array::set_module_and_type("numpy", "ndarray");class_("Spline", init<>()).def("spline", &Spline::spline);}因此在…