MySQL CRUD进阶

  前言👀~

上一章我们介绍了CRUD的一些基础操作,关于如何在表里进行增加记录、查询记录、修改记录以及删除记录的一些基础操作,今天我们学习CRUD(增删改查)进阶操作

如果各位对文章的内容感兴趣的话,请点点小赞,关注一手不迷路,如果内容有什么问题的话,欢迎各位评论纠正 🤞🤞🤞

12b46cd836b7495695ce3560ea45749c.jpeg

个人主页:N_0050-CSDN博客

相关专栏:java SE_N_0050的博客-CSDN博客 java数据结构_N_0050的博客-CSDN博客


数据库约束

含义:数据库,自动的对数据的合法性进行 校验检查 的一系列机制,目的就是为了保证数据

库中能够 避免 被插入/修改 一些非法的数据

7a95205de3ea4afd98365e4d37327683.png


not null

这一列不能填null值(相当于必填项),并且插入和修改都会被限制

create table 表名(列名 类型 not null,列名 类型....);

创建

6a7d0cbcd93d43c1beb4e509b056913a.png

插入

当我们进行插入发现会报错,因为我们设置了id这一列不能为空

2e6fcc9761c24b5b972695fc2ed269fd.png

修改

当我们进行修改的时候也会报错,也是因为我们设置了id这一列不能为空

8d4e8113349044138322ff2c25483f52.png


unique

相当于填写的值不能重复,并且插入和修改都会被限制,且会让后续的 插入和修改数据 的时候,都会先触发一次 查询 的操作(通过这个查询,来确定当前这个记录是否已经存在)

create table 表名(列名 类型 unique,列名 类型...);

创建

88599c26dbeb4c9199cb7990ca246612.png

插入

我们先插入一条数据,然后再插入一条数据但是id跟上一次插入的id一样,发现报错了,结合上面说的后续的插入和修改数据的时候,都会先触发一次 查询的操作,通过这个查询,来确定当前这个记录是否已经存在

8ef0fc2e88214cd898e6b7b3f1e9e25e.png


default

没有给列赋值时,就按默认值进行插入

create table 表名(列名 类型 default '你想默认值显示什么就填什么' ,列名 类型...);

一般没赋值的话,默认都是null

1c2b1d3216ba4dc489f1d21b3ca0cc7f.png

创建

007342cb2f7d484cb44b25b96cab9f90.png

查看表结构

查看表结构的时候,我们会发现name这列default默认值是未命名

611e3b0c92e04ee6b09d39cc4d2668d2.png

查询

当我们只对id列插入数据,去查询发现我们的name这列这行的默认值是我们刚才设置的

b3317377ff6a478bb20e598cfe8840dc.png


primary key(主键,最重要的约束)

确保列有唯一标识,例如我们的身份证,在填写的时候不能为空且不能重复相当于是 not null unique 的结合

create table 表名(列名 类型 primary key,列名 类型);

创建

a24d0a6607c145628090e4c4064fae52.png

查看表结构

3445a157c0b543a38920cb8aac8e0111.png

插入

我们先插入一条数据,第二次插入同样的id会报错,原因是id设置为主键了,值不能重复

e4bd3798ae1a4263999781ed24fcaeb5.png


如何保证主键唯一呢?

mysql提供了一种“自增主键”这样的机制

create table 表名(列名 类型 primary key auto_increment,列名 类型);

创建

9f4009b3f6584e6b8b7dad808d7e3889.png

查看表结构

f3a653d1d3274342ba29589509f3db67.png

插入

我们在插入数据的时候id列设为空,查询的时候会发现它会进行自增

2157b4b18cf3484e85bb51efd6380ca0.png

插入的时候从 刚才的最大值 开始,继续往后分配的

7fee355d84e14a84a33d08ac68eb47fd.png

补充:

这里的id的自动分配,有一定的局限性,如果是单个mysql服务器,没什么问题

如果是一个分布式系统,有多个mysql服务器构成的集群,这个时候依靠 自增主键 就不行了

分布式系统:面临的数据量大(大数据),客户端的请求量(高并发)比较大,一台
服务器搞不定就需要多台机器(分布式)

注意:

一张表里只能有 一个primary key(主键)

虽然只能有一个 主键,但是主键不一定只是一个列,也可以用多个列共同构造一个主键(联合主键)

主键经常会使用 int / bigint

对于带有主键的表来说,每次 插入和修改数据,也会涉及到先触发查询的操作

mysql会把带有 unique 和 primary key 的列自动生成 索引(后续会讲到),从而加快查询速度


foreign key(外键)

保证一个表中的数据匹配另一个表中的值的参照完整性

一个表可以有多个外键,但是只能有一个主键!!!

create table 表名(列名 类型 ,foreign key 列名,列名 类型...,references 另一张表名(列名));

没有设置外键的演示

22cff949ff394e4bb79f8925b1a2030f.png

我们会发现没有设置外键的话,我们在person表里可以插入这条数据,即使在class表里没有存在classid为100的数据


接下来是设置外键的演示

references 此处表示了当前这个表的这一列中的数据,应该出自于另一个表的哪一列

创建

89c26a8789334ea3944e912e31a81e63.png

插入和修改

当我们指定了外键的时候,在插入数据和修改数据的时候都会去做出校验,可以理解为父表约束子表

521cf56eefd343509d8fbf11cb5c3fdc.png

897144e9430142ccbeaf8aaf6e71c4d9.png


  • 对父表进行删除或修改操作

9594a431ce094a56833fb7fcb9b28fdb.png

1df37a0be5be499dafab84b3dd20686e.png

结合上面的操作我们可以理解为两个进行捆绑了的意思一样,比如我们都有的数据不能进行乱动,比如插入、修改、删除等操作,你有我没有的这没什么关系


  • 外键准确来说,是两个表的 列产生关联联系,其他的列是不受影响的!!!

25c51da48896440d83bd93d49be99f48.png

即使用到了,但是不相同的列不受影响

c15bca795c0b412aae59fe4ac40f4424.png


  • 删除父表时,必须先删除子表,否则父表无法删除!!!

错误演示

05d37a8d83b246df8a00134f33242522.png

正常演示

d11192610aae4c82926c1658431f42ae.png


  • 指定外键约束时,要求父表中被关联的这一列,得是 主键 或者 unique(外键用于关联其他表的主键或唯一键)
     

566ab28188d54c7aab50c2818c0d4d1f.png


表的设计

根据实例的需求场景,明确当前要创建几个表,每个表什么样子,这些表之间是否存在一定联系

1.梳理清楚 需求中的“实体”(就是说过的“对象”=>需求中的关键性名词)

一般来说,每个实体,都需要安排一个表,表的列就对应到实体的各个属性

2.再确定好 “实体”之间的关系


一对一:

5840144bab1741da9478ee3da701dfc5.png


一对多:

72d4520f1e2841f78a73d856679ef162.png


多对多:

af40846be82345eba802924250000eac.png


查询操作的进阶

查询可以搭配 插入 使用(把查询语句的查询结果,作为插入的数值

简单点说就是把你在 另外一张表查询出来的结果,插入到你 指定的表 中

insert into 表1 select * from 表2;

先准备两张表

89f70ce6bd3c4040a9fb7bbd7e5e0042.png

接着我们插入

526080c7cf484e00a5ce1f96209c451d.png

注意:

此处,要求查询出来的结果集合列数和类型 要和插入的这个表匹配


聚合查询

聚合查询,相当于是在 行 和 行 之间进行运算

sql中提供了一些“聚合函数”通过聚合函数来完成上述行之间的运算

530aa95fae334c0997794d1a1a71ed63.png
以下这些“聚合函数”要求务必对数字类型进行操作,如果对字符串类型进行操作,会强转成double执行后续的操作

count

select count(列名) from 表名;

用法

ab56c12cb3ea431e924f5b4a8c30f944.png

指定列

这里即使我插入一条数据,还是 name这一列 还是只统计了7条,因为有null值会被排除掉

776d8ac85e3f4410ac3942f80fe0be1c.png

搭配去重使用

6558168e4845463e832c2f9de9acd4a1.png


注意格式:

e11a386e2dcc43a79979ed6d382f0111.png


sum

把这一列的 若干行,进行求和(算术运算,只针对数字类型使用)

select sum(列名,列名...) from 表名;

用法

同样有null值会被排除掉

37e3bab6a8d84c9d84e97fe265cd837b.png


对表达式进行相加

c8a04c0808414f42bc5a91bc72d20861.png


avg:求平均值


max:求最大值


min:求最小值


group by(分组查询)

使用 group by 进行分组(针对指定的列进行分组,把这一列中,值相同的行,分到同一组中,得到若干个组),针对每个分组,再分别进行聚合查询

select 列名,列名... from 表名 group by 列名,列名;

演示

查询每个role对应的平均薪资

根据role这一列进行分组,针对分出来的每一个组再使用avg函数

如果针对分组之后,不使用聚合函数,此时的结果就是查询出每一组的某个代表数据

使用group by的时候,还可以搭配条件

比如我们查询每个岗位的平均工资,排除老三


having

group by子句进行分组以后,需要对分组结果再进行条件过滤时,不能使用 WHERE 语句,而需要用having

select 列名,列名... from 表名 group by 列名,列名 having 条件;

使用having描述条件,having一般写在group by的后面

这里我们演示搭配where和having进行查询


联合查询/多表查询

对比之前的查询,则是一次性对多个表中进行查询

多表查询是对多张表的数据取笛卡尔积

笛卡尔积 工作过程:

1.笛卡尔积的列数,是这两个表的列数相加

2.笛卡尔积的行数,是这两个表的行数相乘

笛卡尔积就是多表查询的基础,多表查询在笛卡尔积的基础上再去进行数据的筛选!

内连接

select 字段 from 1 别名 1 [inner] join 2 别名 2 on 连接条件 and 其他条件 ;
select 字段 from 1 别名 1, 2 别名 2 where 连接条件 and 其他条件 ;

查看表结构

我们去查询 许仙同学的成绩

1.先进行笛卡尔积(数据太多,就展示这些后面慢慢筛选掉)

2.下一步加上连接条件,这里刚好是没有重复的列,如果这个id也叫student_id就会出现重复的列,会有问题,所以要这样写 表名.列名 类似java对象访问成员

3.添加条件进行筛选

4.对列进行精简


我们去查询所有同学的总成绩,及同学的个人信息

同样我们进行笛卡尔积,然后加上连接条件 

然后进行分组,不加 group by

加group by

我们会发现不加group by都算到一个人头上了,加了group by就是每个同学对应的总成绩


查询每个同学,每门课程课程名字和分数

同样要先笛卡尔积,并且加上连接条件,这里涉及到三张表,需要两个连接条件

然后选择要显示的列


外连接

外连接分为 左外连接右外连接。如果联合查询,左侧的表完全显示我们就说是左外连接;右侧的表完全显示我们就说是右外连接。

首先我们先创建两张表然后进行连接

左外连接:

以左侧表为基准,保证左侧表的每个数据都会出现在最终结果里,如果在右侧表中不存在,对应的列就填成null

-- 左外连接,表 1 完全显示
select 字段名   from 表名 1 left join 表名 2 on 连接条件 ;

右外连接:

以右侧表为基准,保证右侧表的每个数据都会出现在最终结果里,如果在左侧表中不存在,对应的列就填成null

-- 右外连接,表 2 完全显示
select 字段 from 表名 1 right join 表名 2 on 连接条件 ;

全外连接:


自连接

自连接是指在同一张表连接自身进行查询

select * from  表 a1, 表 a2 where a1.id=a2.id;

显示所有“计算机原理”成绩比“Java”成绩高的成绩信息

就是同一张表,自己对自己先进行笛卡尔积,并且注意要为这两个表 命一个别名,as可加可不加

接着加上连接条件,以及我们要求的条件

最后挑选出要显示的列

我们进行优化显示学生的所有信息以及课程名


子查询

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询

select 列名 from 表名 where 列名 =、>、<、in等 (select 列名 from 表名 where 条件);

单行子查询:返回一行记录的子查询

例题:查询与“不想毕业” 同学的同班同学

1.先在student表找出不想毕业同学在哪个班

2.接着在student表找出不想毕业的同班同学

3.接下来就是子查询的关键了,我们把id=1换成我们第一次查询的结果


多行子查询:返回多行记录的子查询

例题:查询“语文”或“英文”课程的成绩信息

1.同样第一步我们在course表找出 语文或英文 的id

2.接着联表查询出语文或英文的成绩信息

3.同样我们把 in 后面的条件替换成一开始查询的结果


合并查询

把多个sql查询的结果集合,合并到一起

select 列名 from 表名 union select 列名 from 表名;

例题:查询id小于3,或者名字为“英文”的课程

一般我们的做法是如下

但是 or 只能针对一个表,使用 union 允许两个不同的表,查询结果合并到一起,但是合并的sql的结果集的 要匹配,列的个数和类型要一致

union all

当我们使用 union 的时候发现,它会去重

我们去使用 union all,发现会取消去重

到这就结束了增删改查的进阶操作,知识点还是非常之多,一下子可能消化不了,需要慢慢细品,希望各位能看得懂并且理解进去,我们下一章再见💕

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

mac查看Linux服务器的性能

mac上安装 linux系统 如果有 linux服务器账号密码&#xff0c;那么上一部可忽略&#xff1b; 比如&#xff1a;直接连接阿里云或腾讯云账号 1. 安装termius 链接: https://pan.baidu.com/s/1iYsZPZThPizxqtkLPT89-Q?pwdbw6j 提取码: bw6j 官网 Termius - SSH platform for …

[Linux][网络][TCP][一][TCP基础][TCP报头]详细讲解

目录 1.TCP头部格式2.TCP协议的特点3.TCP如何封装与分用4.通过序列号和确认应答号提高可靠性1.32位序列号2.32位确认应答号3.保证可靠性4.为什么序列号和确认应答号是单独的字段 5.窗口大小1.TCP的发送和接收缓冲区2.窗口大小 6.连接管理机制 1.TCP头部格式 TCP全称为"传输…

C语言数据结构之队列

目录 1.队列的概念及结构2.队列的实现逻辑3.队列的代码实现4.相关例题选择题 •͈ᴗ•͈ 个人主页&#xff1a;御翮 •͈ᴗ•͈ 个人专栏&#xff1a;C语言数据结构 •͈ᴗ•͈ 欢迎大家关注和订阅!!! 1.队列的概念及结构 队列&#xff1a;只允许在一端进行插入数据操作&#x…

SpringBoot与SpringMVC的区别

SpringBoot与SpringMVC的区别是什么&#xff1f; SpringBoot和SpringMVC是Java开发中常用的两个框架&#xff0c;它们都是由Spring框架所提供的&#xff0c;但在功能和使用方式上有着一些区别。本文将分别介绍SpringBoot和SpringMVC的特点和区别。 一、SpringBoot的特点&#…

第16章 基于结构的测试技术(白盒测试技术)

一、静态测试技术 &#xff08;一&#xff09;概述 不运行程序代码的情况下&#xff0c;通过质量准则或其他准则对测试项目进行检查的测试类型&#xff0c;人工或工具检查。 1、代码检查 2、编码规则检查 软件编码规范评测&#xff1a;源程序文档化、数据说明、语句结构、…

wpf线程中更新UI的4种方式

在wpf中&#xff0c;更新UI上面的数据&#xff0c;那是必经之路&#xff0c;搞不好&#xff0c;就是死锁&#xff0c;或者没反应&#xff0c;很多时候&#xff0c;都是嵌套的非常深导致的。但是更新UI的方式&#xff0c;有很多的种&#xff0c;不同的方式&#xff0c;表示的意思…

01-MySQL 基础篇笔记

一、MySQL 概述 1.1 数据库相关概念 数据库&#xff1a;&#xff08;DB&#xff1a;DataBase&#xff09; 存储数据的仓库&#xff0c;数据是有组织的进行存储 数据库管理系统&#xff1a;&#xff08;DBMS&#xff1a;DataBase Management System&#xff09; 操作和管理数…

论文阅读笔记(AAAI 20)Order Matters

个人博客地址 注&#xff1a;部分内容参考自GPT生成的内容 论文笔记&#xff1a;Order Matters&#xff08;AAAI 20&#xff09; 用于二进制代码相似性检测的语义感知神经网络 论文:《Order Matters: Semantic-Aware Neural Networks for Binary Code Similarity Detection》…

时间日志格式的统一和定制

返回当前格式的时间没有错误&#xff0c;但是不符合中国人的阅读习惯 解决&#xff1a; 方案一&#xff1a;JsonFormat 解决后端 传到 前端格式问题 依赖&#xff1a; <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jack…

基于MQTT通信开发的失物招领小程序

项目架构设计 这个项目采用前后端分离的方式&#xff0c;重新设计了两条链路来支撑程序的信息获取和传递 前端的小程序页面再启动页面渲染时&#xff0c;直接通过DBAPI从后端数据库获取信息&#xff0c;直接渲染在小程序中项目中给DBAPI的定位是快速从后端获取信息&#xff0…

C语言 计数控制循环

今天 我们来说 计数控制的循环 对于循环次数 我们已知的循环 我们称之为 计数控制的循环 这种情况 我们一般选择 for来实现 更为方便 先看一个案例 求 1 到 N 的累加合 我们代码可以这样写 #define _CRT_SECURE_NO_WARNINGS//禁用安全函数警告 #pragma warning(disable:6031…

一键自动化博客发布工具,chrome和firfox详细配置

blog-auto-publishing-tools博客自动发布工具现在已经可以同时支持chrome和firefox了。 很多小伙伴可能对于如何进行配置和启动不是很了解&#xff0c;今天带给大家一个详细的保姆教程&#xff0c;只需要跟着我的步骤一步来就可以无障碍启动了。 前提条件 前提条件当然是先下…

数据库MySQL的基本操作

在Linux里面&#xff0c;我们要对数据库MySQL进行操作时&#xff08;例如修改MySQL的密码&#xff09;&#xff0c;不是直接在我们的终端上进行操作&#xff0c;而是通过终端连接进入到MySQL里面去&#xff0c;在进行操作&#xff0c;写SQL语句。 而安装C等的开发库sudo命令&a…

【深度学习驱动的蛋白质设计技术与前沿实践-从基础到尖端应用】

RoseTTAFold&#xff0c;作为 David Baker 教授团队早期开发的蛋白质结构预测工具&#xff0c;在学术界与工 业界广受认可。然而&#xff0c;随着时间推移&#xff0c;仅局限于预测已知结构的蛋白质并不能满足生物医药和生 物工程领域对创新设计的需求。这促使 David Baker 教授…

浅谈ps/2键盘

文章目录 说明基础知识操作系统中断类型工作机制优点应用 CPU对IO设备的轮询机制轮询机制的工作原理轮询机制的特点轮询机制的优、缺点与中断机制的对比 N-Key Roller&#xff08;全键无冲&#xff09;应用领域实现原理技术限制 PS/2接口简介USB设备&PS/2设备的工作机制PS/…

【在线oj系统】02-开发环境版本说明

目录 一、前置环境版本介绍 二、SpringCloud组件停更/替换/更新 服务注册和发现 服务调用和负载均衡 分布式事务 服务熔断和降级 服务链路追踪 服务网关 分布式配置管理 三、客户端版本 一、前置环境版本介绍 使用Cloud的版本决定Boot的版本&#xff0c;SpringCloud的…

大语言模型从Scaling Laws到MoE

1、摩尔定律和伸缩法则 摩尔定律&#xff08;Moores law&#xff09;是由英特尔&#xff08;Intel&#xff09;创始人之一戈登摩尔提出的。其内容为&#xff1a;集成电路上可容纳的晶体管数目&#xff0c;约每隔两年便会增加一倍&#xff1b;而经常被引用的“18个月”&#xf…

【02358单片机原理及应用】第一、二章考试复习知识点期末复习自考复习

单片机原理及应用考试复习知识点 第1章 计算机基础知识 考试知识点&#xff1a; 1、各种进制之间的转换 &#xff08;1&#xff09;各种进制转换为十进制数 方法&#xff1a;各位按权展开相加即可。 &#xff08;2&#xff09;十进制数转换为各种进制 方法&#xff1a;整…

将VM虚拟机Ubuntu20.04系统扩容

一、拓展虚拟机硬盘空间 随着学习的深入&#xff0c;虚拟机里面的内容越来越多&#xff0c;我们可能会面临着硬盘空间不足的问题。今天我们就来沉浸式体验一把给虚拟机扩容。 二、拓展VM虚拟机硬盘前须知 在硬盘拓展时需要注意的一点是有快照的话拓展不了说是&#xff0c;先删除…

分类规则挖掘(一)

目录 一、分类问题概述&#xff08;一&#xff09;分类规则挖掘&#xff08;二&#xff09;分类规则评估&#xff08;三&#xff09;分类规则应用 二、k-最近邻分类法 一、分类问题概述 动物分类&#xff1a;设有动物学家陪小朋友林中散步&#xff0c;若有动物突然从小朋友身边…
最新文章