[MySQL]数据库原理8——喵喵期末不挂科

希望你开心,希望你健康,希望你幸福,希望你点赞!

最后的最后,关注喵,关注喵,关注喵,大大会看到更多有趣的博客哦!!!

喵喵喵,你对我真的很重要!

目录

前言

数据约束和参照完整性

修改UNIQUE约束

FOREIGN KEY参照完整性约束

理解参照完整性

reference_definition语法格式

在创建表时创建外键

对已有的表添加外键

创建级联删除、级联更新

总结


前言

这个章节快要完结啦!让我们去开启新的冒险之旅!!芜湖~


数据约束和参照完整性

修改UNIQUE约束

设置course表的c_noUNIQUE约束。

Mysql>ALTER TABLE course

 ADD UNIQUE (c_name);

思考与总结:

1)尝试向course表中输入同名的课程,会出现什么情况?为什么?

2)一个数据表只能创建一个主键。但一个表可以有若干个UNIQUE,并且它们甚至是可以重合的

3)主键字段的值不允许为NULL,而UNIQUE字段的值可取NULL,但是必须使用NULLNOT NULL声明。

4)一般在创建PRIMARY KEY约束时,系统会自动产生PRIMARY KEY索引。创建UNIQUE约束时,系统自动产生UNIQUE索引。


FOREIGN KEY参照完整性约束

理解参照完整性

  在关系型数据库中,表与表之间往往存在一种“父子”关系。 例如,字段s_no是一个表A的属性,且依赖于表B的主键。那么,称表B为父表,表A为子表。通常将s_no设为表A的外键,参照表B的主键字段,通过s_no字段将父表B和子表A建立关联关系。

  这种关联关系就是参照完整性约束,是一种特殊的完整性约束,实现为一个外键,外键是表的一个特殊字段。

     外键的作用是建立子表与其父表的关联关系,保证子表与父表关联的数据一致性。父表中更新或删除某条信息时,子表中与之对应的信息也必须有相应的改变


reference_definition语法格式

可以在创建表或修改表时定义一个外键声明

 reference_definition语法格式如下:

REFERENCES tbl_name [(index_col_name,...)] [ON DELETE  {RESTRICT | CASCADE | SET NULL | NO ACTION}][ON UPDATE  {RESTRICT | CASCADE | SET NULL | NO ACTION}]

   

要删除或更新父表中被参照列上在外键中出现的值:

RESTRICT(限制):拒绝对父表的删除或更新操作。

CASCADE自动删除或更新子表中匹配的行。

SET NULL:设置子表中与之对应的外键列为NULL

NO ACTIONNO ACTION意味着不采取动作,和RESTRICT一样。

SET DEFAULT:指定子表中的外键列为默认值


在创建表时创建外键

创建salary表,包含employeeidincomeoutcome字段,employeeid作为外键参照employees表的employeeid字段。

mysql> create table salary(employeeid char(6) not null primary key,income float(8) not null,outcome float(8) not null,foreign key(employeeid)  references employees (employeeid)  on update cascade    on delete cascade) character set gb2312  engine=innodb;

对已有的表添加外键

建立一个与salary表结构相同的表salary1,用ALTER TABLE语句向salary1表中的employeeid列添加一个外键。要求当employees表中要删除或修改与employeeid值有关的行时,检查salary1表中有没有该employeeid值 ,如果存在则拒绝更新employees

mysql>alter table salary1add foreign key(employeeid)references employees(employeeid)on update restricton delete restrict;

创建级联删除、级联更新

JXGL库中,将score表的s_no字段参照表studentss_no字段,score表的c_no字段参照coursec_no字段。 当students表的s_no字段,coursec_no字段更新或删除时,score级联更新、级联删除

mysql> ALTER TABLE  score   ADD FOREIGN KEY (s_no)   REFERENCES  students (s_no)   ON UPDATE CASCADE  ON DELETE CASCADE;

mysql> ALTER TABLE  score   ADD FOREIGN KEY (c_no)   REFERENCES  course (c_no)   ON UPDATE CASCADE  ON DELETE CASCADE;

思考与总结

1)外键要求参考的键(父表的键)必须是主键?

2)相关联的外键与主键必须是同域的(即数据类型相同)。

3联的两表应当字符集相同。

        (4)如果父表与子表都有数据,则要求子表外键的数据必须是来源于主键,否则外键约束不成立。


总结

记住了,才是自己的!

人生苦短,一天当作两天卷~


希望你开心,希望你健康,希望你幸福,希望你点赞!

最后的最后,关注喵,关注喵,关注喵,大大会看到更多有趣的博客哦!!!

喵喵喵,你对我真的很重要!

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

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

相关文章

大数据行业英语单词巩固20240410

20240410 Communication - 沟通 Example: Effective communication is essential for project success. 有效的沟通对于项目的成功至关重要。 Collaboration - 协作 Example: Team collaboration is crucial in achieving our goals. 团队协作对于实现我们的目标至关重要。 …

数字化仪:为何成为示波器的理想替代品?——PCIe8910M

在现代科技领域,数字化仪逐渐成为示波器的理想替代品。数字化仪具备诸多特点,使其在多个应用场景下表现出色,逐渐取代传统的示波器。本期文章将探讨数字化仪相对于示波器的优势,以及其哪些特点使其成为示波器的理想替代品。 简介…

【Datawhale LLM学习笔记】一、什么是大型语言模型(LLM)

文章目录 1. 什么是大模型2. 检索增强生成 RAG一、什么是 RAG二、RAG 的工作流程 3. langChain介绍一、什么是 LangChain二、LangChain 的核心组件 4. 开发 LLM 应用的整体流程一、何为大模型开发二、大模型开发的一般流程三、搭建 LLM 项目的流程简析(以知识库助手…

产品推荐 | 基于Lattice CrossLink-NX FPGA语音和视觉机器学习板

01 产品概述 Lattice Semiconductor CrossLink-NX语音和视觉机器学习板是高性能 – 专为低功耗机器学习应用而设计的电路板,采用CrossLink-NX 40K,这是一款具有AI加速器的强大FPGA。 基于视觉和语音的机器学习应用 – 板载低功耗图像传感器和麦克风以及…

Linux数据库自动备份 - 定时任务发到百度云盘、坚果云、邮箱附件

前言 1. 坚果云的webdav云盘最好! (免费账号每月1G上传流量) 2. 不建议数据库备份文件发送到SMTP邮箱,因为对方服务器非常容易当做垃圾邮件处理,而且发信的SMTP账号会被封禁(实测163发到QQ邮箱被封&…

数据库一个字段对应多个参数值设计

数据库只有一个字段存多个开启(参数值只有开启和关闭的参数) 只有一个参数是设置为1 加一个参数是设置为112 再加一个参数是设置为1214 ..... 依此类推后一个参数的值前面所有参数的和1例如 控制参数1 控制参数2 控制参数3 控制参数4 上面有4个参数…

更改docker镜像下载地址

一.简介 使用指令 sudo docker info 查看本机的docker镜像下载地址为 由于本机的var文件空间不足,因此,想更改他的存储地址,如下 二.开始操作 1.停止Docker服务: 执行命令 sudo systemctl stop docker 以及 sudo systemctl s…

leetcode热题HOT146. LRU 缓存

一、问题描述: 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存 int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值…

220V转3.3V线性降压芯片WT5100

220V转3.3V线性降压芯片WT5100 WT5100就是那个离线式的稳压器芯片,没有电感的那种。里面内置了650V的大功率MOSFET,启动控制电路,电压控制电路,交流信号检测电路等等。通过切换SEL管脚,它就能输出5V或3.3V的电压。不需…

一本免费开源的电子书籍!这个 71.8k star 的项目,让你轻轻松松学会算法【文末有福利】

话说作为一名程序员,肯定都少不了在准备面试的时候刷 LeetCode 的算法题吧。虽然面试考察的算法题在工作中用到的非常少,但是确实是能让我们对常用的数据结构有更深刻的理解,以及对思维逻辑有很大的提升。不过枯燥的刷题可能让新手无从下手&a…

【Linux网络编程】UDP协议

UDP协议 1.再谈端口号端口号划分认识知名端口号(Well-Know Port Number)两个问题netstatpidof 2.UDP协议2.1UDP的特点2.2面向数据报2.3UDP的缓冲区2.4UDP使用注意事项2.5基于UDP的应用层协议 喜欢的点赞,收藏,关注一下把! 1.再谈端口号 端口…

【Unity优化(二)】渲染优化

https://www.cnblogs.com/alan777/p/6204759.html CPU受限 开启Player Settings中的Graphics jobs。 在Player settings中的Graphics jobs选项决定了Unity是否使用工人线程去执行一些原本需要在主线程或者渲染线程中执行的任务,在支持这个功能的平台上&#xff0…

mysql匹配

文章目录 匹配和正则表达式匹配:like正则表达式:rlike(与regexp完全一样没有区别) 匹配和正则表达式 匹配:like %:用来匹配 0 个或多个字符 _:用来匹配1个字符 SELECT * FROM Websites WHER…

计算方法实验5:对鸢尾花数据集进行主成分分析(PCA)并可视化

任务 iris数据集包含150条数据,从iris.txt读取,每条数据有4个属性值和一个标签(标签取值为0,1,2)。要求对这150个4维数据进行PCA,可视化展示这些数据在前两个主方向上的分布,其中不…

笔记84:关于递归法的一些感悟

题目1:二叉树的前序遍历 链接:. - 力扣(LeetCode) /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(…

京东详情比价接口优惠券(2)

京东详情API接口在电子商务中的应用与作用性体现在多个方面,对于电商平台、商家以及用户都带来了显著的价值。 首先,从应用的角度来看,京东详情API接口为开发者提供了一整套丰富的功能和工具,使他们能够轻松地与京东平台进行交互。…

后台运行程序时报错

问题描述:使用pycharm连接服务器运行程序时,可以正常运行。但是使用Termius终端运行时报错(运行时切换到和pycharm相同的路径)。 2024-04-15 14:35:01.663900: I external/local_xla/xla/stream_executor/cuda/cuda_dnn.cc:454] …

jeecg 3.4.3前后端分离获取,前端获取当前登录人信息

1. store —>modules—>user.js下 可以查看有哪些信息 2. 使用方式 2.1 //获取登录用户的信息 import user from ‘/store/modules/user’ 2.2 export下 export default { user } 2.3 可以在created中直接打印信息 const useruser.state; console.log(“当前登录人:”…

USB设备热插拔流程解析

设备热插拔 i2c,spi都是主机驱动初始化的时候,就会根据设备树来添加设备 pci的话,主机初始化的时候,会通过总线去遍历枚举card设备 sdio的话,主机驱动初始化的时候,会去枚举卡;插卡可能会触发主机中断&a…

物业满意度调查如何开展?

物业管理行业的服务水平对于提升居民生活质量、维护社区安全和保障房产价值起着重要作用,近年来受地产关联方房屋交付影响,以及疫情后物业投入减少,物业企业对社区环境、设施和公共区域的维护减弱,2023年的降幅尤其明显&#xff0…