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

news2024/11/15 20:57:57

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

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

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

目录

前言

数据约束和参照完整性

修改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 salary1

    add foreign key(employeeid)

    references employees(employeeid)

    on update restrict

    on 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.coloradmin.cn/o/1596201.html

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

相关文章

Vulnhub靶机 DC-2渗透详细过程

VulnHub靶机 DC-2 打靶 目录 VulnHub靶机 DC-2 打靶一、将靶机导入到虚拟机当中二、攻击方式主机发现端口扫描服务探针爆破目录web渗透信息收集扫描探针登录密码爆破SSH远程登录rbash提权 一、将靶机导入到虚拟机当中 靶机地址: https://www.vulnhub.com/entry/dc…

51单片机入门_江协科技_27~28_OB记录的自学笔记_AT24C02数据存储秒表

27. AT24C02(I2C总线) 27.1. 存储器介绍 27.2. 存储器简化模型介绍,存储原理 27.3. AT24C02介绍 •AT24C02是一种可以实现掉电不丢失的存储器,可用于保存单片机运行时想要永久保存的数据信息 •存储介质:E2PROM •通讯接口:I2…

如何在Linux系统部署Joplin笔记并结合内网穿透实现无公网IP远程访问

文章目录 1. 安装Docker2. 自建Joplin服务器3. 搭建Joplin Sever4. 安装cpolar内网穿透5. 创建远程连接的固定公网地址 Joplin 是一个开源的笔记工具,拥有 Windows/macOS/Linux/iOS/Android/Terminal 版本的客户端。多端同步功能是笔记工具最重要的功能,…

极大似然估计、最大后验估计、贝叶斯估计

机器学习笔记 第一章 机器学习简介 第二章 感知机 第三章 支持向量机 第四章 朴素贝叶斯分类器 第五章 Logistic回归 第六章 线性回归和岭回归 第七章 多层感知机与反向传播【Python实例】 第八章 主成分分析【PCA降维】 第九章 隐马尔可夫模型 第十章 奇异值分解 第十一章 熵…

NzN的数据结构--外排序

接上文,本篇向大家简单展示一下外排序的实现。先三连后看才是好习惯!!! 在我们刚接触数据结构的时间里,我们只需要对外排序简单了解一下即可,重点要掌握的还是前面我们介绍的比较排序和非比较排序里的计数排…

基于java的社区生活超市管理系统

开发语言:Java 框架:ssm 技术:JSP JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat11 开发软件:eclipse/myeclip…

爱比对软件:您的文本比对专家

在处理文本时,无论是学术研究、法律审查还是软件开发,精确的文本比对都至关重要。爱比对软件通过先进的技术,为您提供了一系列核心功能,旨在优化您的工作流程和数据管理,确保您的文档内容准确无误。 爱比对软件&#…

白盒测试之语句覆盖与分支(判定)覆盖

白盒测试之语句覆盖与分支(判定)覆盖(蓝桥云学习笔记) 1、语句覆盖 实验介绍 白盒测试的目的是通过检查软件内部的逻辑结构,对软件中的逻辑路径进行覆盖测试。控制流分析是白盒测试中的一种重要测试方法,…

实时传输,弹性优先——物联网通讯打造数据上传新标杆

随着信息技术的飞速发展,物联网技术已经成为连接物理世界和数字世界的桥梁。在物联网领域,数据上传的速度、稳定性和灵活性是评价通讯技术优劣的重要指标。近年来,物联网通讯在实时传输、弹性优先方面取得了显著进展,为数据上传树…

第42篇:随机存取存储器(RAM)模块<一>

Q:本期开始我们分期介绍随机存取存储器(RAM)模块及其设计实现方法。 A:随机存储器RAM,即工作时可以随时从一个指定地址读出数据,也可以随时将数据写入一个指定的存储单元。 DE2-115开发板上的Cyclone IV …

java-通过maven导入本地jar包常见的两种方式

一、准备工作 1.1 写一个小demo,将其打包 1.2 再新建一个项目,并在项目文件夹里新建一个lib文件夹,将上个jar包放进去。 二、方法一(重要) 找到那个小demo 的pom 文件将其中的三个信息拷贝到新项目中去 接着 调用demo…

【计算机系统结构】流水方式(续)

📝本文介绍 本文总结了流水机器的相关处理以及非线性流水线的调度 👋作者简介:一个正在积极探索的本科生 📱联系方式:943641266(QQ) 🚪Github地址:https://github.com/sankexilianhua &#x1f…

2A大电流线性稳压器具备两种输出电压范围

概述 PCD3931 是一款低噪声、低压差线性稳压器 (LDO),可提供 2A 输出电流,最大压降仅为 160mV。该器件提供两种输出电压范围。 PCD3931 的输出电压可通过外部电阻分压器在 0.5V 至 5.5V 范围内进行调节。PCD3931 集低噪声、高 PSRR 和高输出电流能力等特…

国密证书VS国外证书:选哪种更靠谱?一文带你了解优劣势!

在数字化生活的今天,无论是网上购物、在线支付还是远程办公,我们的信息安全和隐私保护都显得尤为重要。而数字证书,就像是一把“信任钥匙”,帮助我们确认信息的真实性和保护数据的安全。但是,面对国密证书和国外品牌证…

Java | Leetcode Java题解之第22题括号生成

题目&#xff1a; 题解&#xff1a; class Solution {static List<String> res new ArrayList<String>(); //记录答案 public List<String> generateParenthesis(int n) {res.clear();dfs(n, 0, 0, "");return res;}public void dfs(int n ,int…

【派兹互连-SailWind】这家公司悄然入局,国产EDA突围又有新看头了!

从光刻机到EDA软件&#xff0c; 国产厂商何以突围&#xff1f; 两年前&#xff0c;美发布禁令直接把对中国大陆半导体产业的限制&#xff0c;从光刻机扩大到集成电路所必需的EDA软件领域&#xff0c;在此之前华为因被美国列入实体清单&#xff0c;被三大海外EDA巨头断供&…

MOM系统:制造企业的“神级助手“!

一、大环境下的智能化改造 嘿&#xff0c;亲爱的制造企业老板们&#xff0c;你们是否曾经为生产计划混乱、物料和设备管理无序、产品质量不稳定等等问题而头疼不已&#xff1f;现在&#xff0c;有一个超级助手可以帮助你们解决这些问题&#xff0c;那就是MOM系统&#xff01;什…

《前端面试题》- JS基础 - 伪数组

第一次听说伪数组这个概念&#xff0c;听到的时候还以为是说CSS的伪类呢&#xff0c;网上一查&#xff0c;这东西原来还是个很常见的家伙。 何为伪数组 伪数组有两个特点&#xff1a; 具有length属性&#xff0c;其他属性&#xff08;索引&#xff09;为非负整数但是却不具备…

Python 操作 json 数据

在Python中&#xff0c;操作JSON数据主要包括序列化&#xff08;将Python对象转换为JSON格式&#xff09;和反序列化&#xff08;将JSON字符串转换回Python对象&#xff09;。 以下是使用Python内置的json模块进行这些操作的基本示例&#xff1a; JSON 序列化 (Serialization…

记一次事件到供应链的顶级拉扯

前言 某天&#xff0c;夜里3点 天刚蒙蒙亮 开局&#xff1a;我有一个朋友~ 看不懂发的什么意思&#xff0c;再仔细看看&#xff0c;懂了! 闲言少叙&#xff0c;遇事不决先上bp&#xff0c;启动&#xff01; 进去之后发现基本没什么实际功能点&#xff0c;像假的一样。注意这里…