【MySQL】MySQL 表的增删改查(进阶)

news2024/12/24 8:13:46

欢迎关注个人主页:逸狼


创造不易,可以点点赞吗~

如有错误,欢迎指出~



目录

约束类型 

not null 非空

unique 唯一

default 指定默认值

primary key 主键

foreign key 外键

check字句  检查

表设计

确定实体  

实体之间的关系

聚合查询

聚合函数

count  计算列的行数

sum  计算列的和

group by 分组查询

搭配条件使用group by

分组之前的条件  用where

分组之后的条件  用having

同时包含 

联合查询(多表查询)

内连接  外连接 和 自连接

内连接

外连接 

左外连接

右外连接

​编辑

自连接

练习 

多表查询的步骤

多表查询 使用join

自连接 练习 

子查询

合并查询

union

union all 


约束类型 

not null 非空

指示某列不能存储 NULL 值。

unique 唯一

保证某列的每行必须有唯一的值。

default 指定默认值

规定没有给列赋值时的默认值。

primary key 主键

not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标 识,有助于更容易更快速地找到表中的一个特定的记录。 大部分情况下,都是用数字作为主键(当然有时候会使用是字符串).

 但是数据库 允许把多个列共同作为一个主键(联合主键)

mysql 提供" 自增主键" 自动分配(auto_increment) 主键,自增主键只针对 int/ bigint 整数.

foreign key 外键

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

 父表约束子表,子表也会对父表反向约束~

若要删除父子表,  确保先删除 子表,在删除 父表 

check字句  检查

保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略 CHECK子句。(MySQL不支持check,但是写了check 不会报错 ,检测条件不会生效)

表设计

根据实际需求, 创建几个表, 每个表有哪些列,以及多个表之间有哪些联系 (即确定 需求中的"实体" 和"联系")

确定实体  

针对"实体" 抽象出其 特点,提取出需要用到的关键信息,

有几个实体,一般就会有几个表,每个实体用一个表来表示 

实体之间的关系

  1. 一对一关系, 如:一个学生对应一个学号,一个学号只能属于一个学生
  2. 一对多关系, 如:一个学生只能属于一个班级,但一个班级可以包含多个学生
  3. 多对多关系, 如:一个学生可以选多个课程,一门课程也可以被多个学生选择
  4. 没关系

聚合查询

聚合函数

count  计算列的行数

下图myql语句是 先执行select * from exam_result , 根据第一句的结果再执行count

结果中包含null ,可能会对上面的结果 产生影响(会把null也算在结果中) 但select 列名,遇到空值 不会进行计数.

sum  计算列的和

需要确保该列是数字用于计算

null和其他数值进行各种运算,结果都为null,  但sum会跳过null,不参与计算.

若是字符串,会出问题

avg() ,max() ,min() 等函数同理~

group by 分组查询

使用group by 指定一个列,会把列的值相同行归到一组

在上图的基础上排个序

搭配条件使用group by

分组之前的条件  用where

查询每个岗位的平均薪资,但是除去张三

分组之后的条件  用having

查询每个岗位的平均薪资,排除平均薪资超过5w的记录

同时包含 

查询每个岗位的平均薪资,排除张三,也排除平均薪资超过5w的记录

联合查询(多表查询)

笛卡尔积:将两个表按照一定的规律 排列组合

如图先创建两个表,一个学生表,一个班级表,它们通过classId联系在一起

内连接  外连接 和 自连接

 mysql支持内连接和 外连接,下面用两个表举例

内连接

内连接查询结果 只包含两个表 同时具备的数据

也可以使用 inner join 来写 内连接,其中inner 可以省略 

外连接 

左外连接

以左表为基准,确保左表的每个记录都出现在最终结果中,若左表的记录在右表中 没有对应的记录,就会把右表相关字段填成 null

右外连接

 mysql不支持 全外连接~

自连接

自己和自己进行 笛卡尔积,本质上是 把 行关系转换成 列 关系 

如果发现 要查询的条件 是针对两行 而不是两列时 就可以考虑使用 自连接

但是自连接的时候 ,表非常大, 此时的连接开销会非常大,容易把数据库 搞挂

练习 

多表查询的步骤

  1. 明确要查询的信息 来自那些表
  2. 对这些表进行笛卡尔积(前提是可以进行 笛卡尔积)
  3. 指定连接条件,将有意义的数据筛选出来
  4. 根据需要进一步指定条件,对数据进行筛选(新加的条件 往往通过and 方式连接)
  5. 进一步针对查询的列 进行精简 

1. 查询“许仙”同学的 成绩

多表查询 使用join

使用join on和使用 where 本质上都是一样的,where是全部写在了一起,也是两两连接,join on 更突出筛选的过程

2. 查询所有同学的总成绩,及同学的个人信息:

select student.id,student.name,sum(score.score) from student join score

on student.id = score .student_id group by student.name;使用join实现上面功能

查询所有同学的成绩,及同学的个人信息:

使用join 实现上图效果 

自连接 练习 

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

子查询

实际上就是 两个简单查询的套娃,也叫 嵌套查询, 不建议 使用

练习:  查询与“不想毕业” 同学的同班同学:

若将其拆成 两个 查询, 显然是更方便 程序员思考

 多子行查询

此时不能使用 = > < 这样的运算符 直接比较了,但可以使用 in

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

若分成3个sql语句

合并查询

union

该操作符用于取得两个结果集的并集。会 自动去掉结果集中的重复行。

使用or达到相同效果,但是适用范围没有union 广泛

  select * from course where id <3 or name = '英文';

union all 

该操作符用于取得两个结果集的并集。不会去掉结果集中的重复行。

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

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

相关文章

基于SSM的学生信息管理系统的设计与实现 (含源码+sql+视频导入教程+文档+VISIO图)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于SSM的学生信息管理系统12拥有三种角色&#xff1a;学生、教师、管理员 学生&#xff1a;选课、查看已选课程、查看成绩 教师&#xff1a;成绩管理 管理员&#xff1a;课程管理、学生…

ai变声:视频怎么变音?分享6个语音变声器,视频变声不再难!

想过如何让自己的直播内容更吸引人吗&#xff1f;你是否希望通过变声器来打造独特的声音效果&#xff1f;或者&#xff0c;如何用创意声音提升观众的互动体验呢&#xff1f;随着直播行业的不断发展&#xff0c;每位主播都在努力寻找吸引观众的独特方式&#xff0c;而变声器正是…

【电脑使用耳机录音注意事项】

文章目录 电脑音设置 电脑音设置 打开声音设置&#xff1a;右键小喇叭 → 选择“声音(S)”→选择 “录制”&#xff1a; 选择 “阵列麦克风” 调整声音大小&#xff1a; 音频增强设置

AI大模型编写多线程并发框架(六十二):限流和并发度优化

系列文章目录 文章目录 系列文章目录前言一、项目背景二、第三轮对话-补充异步执行代码三、第四轮对话-增加限流器四、第五轮对话-抽取限流器接口五、第六轮对话-修改并发度三、参考文章 前言 在这个充满技术创新的时代&#xff0c;AI大模型正成为开发者们的新宠。它们可以帮助…

何为MethodHandles?

最近在梳理ThreadPoolExecutor&#xff0c;无意间看到其内部类Worker实现了一个名字叫做AbstractQueuedSynchronizer的抽象类。看到它&#xff0c;我便想起当年为了面试而疯狂学习这个知识点的场景。不过这种临时抱佛脚的行为&#xff0c;并未给我带来即时的收益。也是这次的疯…

基于Java的高校学生工作系统的设计与实现(论文+源码)_kaic

基于Java的高校学生工作系统的设计与实现(论文源码)_kaic 摘 要 本系统为高校学生工作管理系统&#xff0c;系统能够为高校提供便捷的学生信息管理功能。该系统采用 Java 语言编写&#xff0c;系统采用MVC架构进行设计&#xff0c;通过Servlet和JSP等技术实现前后端数据交互和…

【漏洞复现】SuiteCRM responseEntryPoint Sql注入漏洞

免责声明&#xff1a; 本文内容旨在提供有关特定漏洞或安全漏洞的信息&#xff0c;以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步&#xff0c;并非出于任何恶意目的。阅读者应该明白&#xff0c;在利用本文提到的漏洞信息或进行相关测…

基于UDS的Flash 刷写——BootLoad刷写流程详解

从0开始学习CANoe使用 从0开始学习车载测试 相信时间的力量 星光不负赶路者&#xff0c;时光不负有心人。 目录 流程概述UDS流程详解释前编程①诊断会话控制 - 切换到扩展会话&#xff08;10 03&#xff09;②例程控制-预编程条件检查&#xff08;31 01 02 03&#xff09;③DTC…

ClickHouse分布式部署搭建单分片二副本集群

搭建单分片二副本集群,使用MergeTree引擎测试数据同步 服务器: 127.0.0.1 clickhouse 127.0.0.2 clickhouse + keeper 结构图 1.修改hosts vi /etc/hosts 添加需要部署的ip和名字 127.0.0.1 node1 127.0.0.2 node2 2. node1配置文件修改 2.1 修改/etc/clickhouse-se…

Excel中使用VBS自定义函数将中文转为拼音首字母

1、在“开发工具”中&#xff0c;点击“Visual Basic”。如果没有“开发工具”&#xff0c;则添加。 2、添加“模块”&#xff0c;在窗口中添加自定义函数。 Function MyGetPYChar(char) MyCodeNumber 65536 Asc(char) If (MyCodeNumber > 45217 And MyCodeNumber <…

【网络安全】缓存配置错误导致授权绕过

未经许可,不得转载。 文章目录 正文复现正文 一个电子商务网站,它有 2 个资产:target.com和admin.target.com target.com是面向用户的门户,用户可以去那里购买物品。admin.target.com是卖家的管理门户,卖家可以在其中列出他们的物品,跟踪订单、客户信息等。 我正在测试…

有希带你深入理解指针(3)

前言 本篇文章是对指针知识的进一步讲解&#xff0c;如果对部分知识有不了解的地方可以移步前文进行学习&#xff01; 1.字符指针变量 该内容我们在前面的文章中已提到过&#xff0c;想必大家对它应该不陌生吧&#xff01;这里我们会对它进行详细的介绍。 一般情况下&#xf…

FPGA开发——IIC实现简单的串口回环

一、概述 在我们进行日常开发时&#xff0c;不管是进行MCU、单片机、还是FPGA&#xff0c;都会使用到IIC通信协议。采用串行总线可以简化系统硬件结构、减小系统体积、提高系统可靠性。常 用的串行总线有单总线&#xff08;1-Wire Bus&#xff09;、IIC&#xff08;Inter-Integ…

Codeforces Round 926 (Div. 2) C. Sasha and the Casino (博弈论*1400)

这里的意思是想让我们求得是否是能够实现不停地无上限的赚钱。 这里注意避开一个思维误区&#xff0c;如果你想的是前x次一直用1枚硬币然后吃第x1次保底&#xff0c;那么就是错误的。你应该考虑到如果前x次里面出现了胜利呢&#xff1f;这时候你拿着一枚硬币根本赚不回本。 所…

全志H616系统启动和登录

一、系统启动 刷完机烧入镜像&#xff0c;直接用MobaXterm软件串口登陆 约定固定的波特率115200。 默认登录&#xff1a; 用户&#xff1a;orangepi 密码&#xff1a;orangepi 或用户&#xff1a;root 密码&#xff1a;orangepi 在输入密码时…

YOLO 单目测距:原理、方法与代码

一、原理 单目测距的一个常见方法是假设物体的尺寸已知。通过测量物体在图像中的高度&#xff08;或宽度&#xff09;&#xff0c;并结合物体的实际高度&#xff08;或宽度&#xff09;&#xff0c;最简单的一种方式就是利用相似三角形的原理来计算物体的距离。 二、相似三角…

使用深度学习来进行击剑动作识别的裁判工作

在击剑比赛中&#xff0c;当双方几乎同时击中对方时&#xff0c;记分板两边都会亮起。这时裁判需要决定哪一方得分。一般而言&#xff0c;谁更主动或控制了局势就会得分。我尝试训练了一个模型来辅助裁判做这样的判断&#xff01;目前该模型在花剑测试集上的准确率大约为60%&am…

Vue开发者工具安装详细教程

欢迎大家订阅【Vue2Vue3】入门到实践 专栏&#xff0c;开启你的 Vue 学习之旅&#xff01; 文章目录 前言一、下载二、安装三、调试 前言 Vue 是一个框架&#xff0c;也是一个生态&#xff0c;其功能覆盖了大部分前端开发常见的需求。本文详细讲解了 Vue 开发者工具的安装。 …

ES7.17.5 float类型 terms带来的隐患

背景 1.用户在mapping中加一个字段 testid&#xff0c;结果写数据的时候使用 testId&#xff0c;同时也没有strict限制动态mapping&#xff0c;只是使用了默认的 true&#xff0c;即允许动态生成mapping 2.动态生成的字段 testId 被识别成了 float&#xff0c;用户为了方便&a…

【Netty 一】

Netty是什么 Netty 是一个高性能、异步事件驱动的 NIO 框架&#xff0c;基于 JAVA NIO 提供的 API 实现。它提供了对 TCP、 UDP 和文件传输的支持&#xff0c;作为一个异步 NIO 框架&#xff0c; Netty 的所有 IO 操作都是异步非阻塞 的&#xff0c; 通过 Future-Listener 机制…