【从删库到跑路】MySQL数据库的查询(单表查询,多表查询,内外连接,联合查询,子查询)

🎊专栏【MySQL】
🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。
🎆音乐分享【如愿】
大一同学小吉,欢迎并且感谢大家指出我的问题🥰

文章目录

  • 🍔多表查询
    • ⭐多表关系
      • 🎈一对多(多对一)
        • 🏀实现
      • 🎈多对多
        • 🏀实现
        • 🏀以图形化的方式来表示
      • 🎈一对一
        • 🏀实现:
        • 🏀以图形化的方式展示
    • ⭐多表查询语法
      • 🎈单表查询
      • 🎈多表查询
        • 🏀我们发现,最终的结果有16条,但是是为什么呢
      • 🏳️‍🌈笛卡儿积
        • 🏀消除无效的笛卡儿积
    • ⭐内连接
      • 🎈隐式内连接
      • 🎈显示内连接
    • ⭐外连接
      • 🎈左外连接
      • 🎈右外连接
    • ⭐自连接
    • 🌺联合查询
      • 🎈union all
      • 🎈union
    • 🌺子查询
      • 🎄标量子查询
      • 🎄列子查询
      • 🎄行子查询
      • 🎄表子查询

在这里插入图片描述

🍔多表查询

⭐多表关系

在项目开发中,在进行数据库表结构设计时,会根据业务需求以及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在各种联系,基本分为以下三种

  • 一对多(多对一)
  • 多对多
  • 一对一

🎈一对多(多对一)

案例:部门和员工之间的关系
关系:一个部门对于多个员工,一个员工对应一个部门

🏀实现

的一方建立外键,指向的一方的主键
在这里插入图片描述

🎈多对多

案例:学生与课程之间的关系
关系:一个学生可以选修多门课程,一门课程也可以供多个学生选择

🏀实现

建立第三张中间表,中间表至少包含两个外键分别关联两方主键
在这里插入图片描述
🏳️‍🌈创建两个表并且插入数据

create table student(
    id int auto_increment primary key comment '主键ID',
    name varchar(10) comment '姓名',
    no varchar(10) comment '学号'
) comment '学生表';

insert into student values (null,'小吉','123'),(null,'fufu','123'),(null,'御坂美琴','123'),(null,'海绵宝宝','123');

在这里插入图片描述

create table course(
    id int auto_increment primary key comment '主键ID',
    name varchar(10) comment '课程名称'
) comment '课程表';

insert into course values (null,'java'),(null,'php'),(null,'mysql'),(null,'c嘎嘎');

在这里插入图片描述

🏳️‍🌈创建第三个表
通过第三个表来维护他们之间的关系

create table student_course(
    id int auto_increment comment '主键' primary key,
    studentid int not null comment '学生ID',
    courseid  int not null comment '课程ID',
    constraint fk_courseid foreign key (courseid) references course(id),
    constraint fk_studentid foreign key (studentid) references course(id)
)comment '学生课程之间表';

insert into student_course values (null,1,1),(null,1,2),(null,1,3),(null,2,2),(null,2,3),(null,3,4);

在这里插入图片描述

🏀以图形化的方式来表示

在这里插入图片描述

🎈一对一

案例:用户与用户详情的关系
关系:一对一关系,多用于单表拆分,将一张表的基础字段放在一张表中,其他详情字段放在另一张表中,以提升操作效率

🏀实现:

在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的(unique)

在这里插入图片描述
先建立表

create table tb_user(
    id int auto_increment primary key comment '主键ID',
    name varchar(10) comment '姓名',
    age int comment '年龄',
    gender char(1) comment '1: 男 , 2:女 ',
    phone char(11) comment '手机号'
) comment '用户基本信息表';

在这里插入图片描述

先建立表

create table tb_user_edu(
    id int auto_increment primary key comment '主键ID',
    degree varchar(20) comment '学历',
    major varchar(20) comment '专业',
    primaryschool varchar(50) comment '小学',
    middleschool varchar(50) comment '中学',
    university varchar(50) comment '大学',
    userid int unique comment '用户ID',
    constraint fk_userid foreign key (userid) references tb_user(id)
)comment '用户教育信息表';

在这里插入图片描述

然后向表中插入数据

insert into tb_user(id, name, age, gender, phone) values
        (null,'小吉','1','2','3'),
        (null,'小吉','1','2','3'),
        (null,'小吉','1','2','3'),
        (null,'小吉','1','2','3');


insert into tb_user_edu(id, degree, major, primaryschool, middleschool, university, userid) values
         (null,'博士','计算机','1','1','哔哩哔哩大学',1),
         (null,'博士','计算机','1','1','哔哩哔哩大学',2),
         (null,'博士','计算机','1','1','哔哩哔哩大学',3),
         (null,'博士','计算机','1','1','哔哩哔哩大学',4);

一条userid就对应一个用户的基本信息

在这里插入图片描述

🏀以图形化的方式展示

在这里插入图片描述

⭐多表查询语法

select * from1,表2,……;

🎈单表查询

在这里插入图片描述

🎈多表查询

在这里插入图片描述

🏀我们发现,最终的结果有16条,但是是为什么呢

在这里插入图片描述
因为44=16
course中有4条,student中有4条,44=16

这种现象称为笛卡儿积

🏳️‍🌈笛卡儿积

是指在数学中,集合A和集合B的所有的组成情况
在这里插入图片描述
当前就是两张表所有的组成情况
但是在设计开发中,我们不需要这么多的情况,我们需要消除无效的情况

🏀消除无效的笛卡儿积

select * from course ,student where course.id=student.id;

在这里插入图片描述

⭐内连接

在这里插入图片描述

🎈隐式内连接

select 字段列表 from1,表2 where 条件……;

查询学生的姓名以及关联的课程

select student.name,course.name from student,course where student.id=course.id;

在这里插入图片描述

🎈显示内连接

select 字段列表 from1 (inner) join2 on 连接条件……;

查询学生的姓名以及关联的课程

select student.name,course.name from student inner join  course on student.id=course.id;

在这里插入图片描述

⭐外连接

🎈左外连接

在这里插入图片描述

🤖相当于查询左表的所有数据 包含 左表和右表交集部分的数据

select 字段列表 from1 left (outer) join2 on 条件……;

会查询到左表的所有数据

在这里插入图片描述
左表
在这里插入图片描述

🎈右外连接

在这里插入图片描述

🤖相当于查询右表的所有数据 包含 左表和右表交集部分的数据

select 字段列表 from1 right (outer) join2 on 条件……;

会查询到右表的所有数据

在这里插入图片描述

⭐自连接

就是在同一张表中进行查询
需要把一张表看作两张表

自连接必须起别名

在这里插入图片描述
原来的表
在这里插入图片描述

🌺联合查询

对于联合查询(union),就是把多次查询的结果合并起来,形成一个新的查询结果集

查询到的多张表的列数要保持一致,而且字段列表也要保持一致

select 字段列表 from 表A……
union (all)
select 字段列表 from 表B……;

🎈union all

合并查询到的两个表,不进行查重

🎈union

合并查询到的两个表,进行查重

在这里插入图片描述
这里我们发现,“鹿杖客”出现了两次
那么我们可以去掉all来去重
在这里插入图片描述

🌺子查询

SQL语句中嵌套select语句,称为嵌套查询,又称为子查询

select * from t1 where column1 = ( select column1 from t2 );

子查询的外部语句可以是insert update delete selete的任何一个

🏳️‍🌈根据查询结果不同,分为

查询方式查询结果
标量子查询子查询结果为单个值
列子查询子查询结果为一列
行子查询子查询结果为一行
表子查询子查询结果为多行多列
🏳️‍🌈根据子查询位置,分为where之后,from之后,select之后

🎄标量子查询

使用操作符 = > < >= <=
查询结果返回的是单个值这种最简单的方式
在这里插入图片描述

🎄列子查询

子查询返回的是一列(可以是多行)
常用操作符:in,not in,any,some,all

操作符描述
in在指定的集合范围之内,多选一
not in不在指定的集合范围之内
any子查询返回列表中,有任意一个满足即可
some与any等同,使用some的地方都可以使用any
all子查询返回列表的所有值都必须满足

在这里插入图片描述
在这里插入图片描述

🎄行子查询

子查询返回的是一行(可以是多列)
常用操作符:= <> in ,not in
在这里插入图片描述
或者
在这里插入图片描述

🎄表子查询

子查询返回的是多行多列
常用运算符:in
在这里插入图片描述

🥰如果大家有不明白的地方,或者文章有问题,欢迎大家在评论区讨论,指正🥰

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

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

相关文章

数学建模常用算法之主成分分析

数学建模常用算法之主成分分析 引言步骤实例以及代码 引言 主成分分析是一种降维算法&#xff0c;它能将多个指标转换为少数几个主成分&#xff0c;这些主成分是原始变量的线性组合&#xff0c;且彼此之间互不相关&#xff0c;且能反映出原始数据的大部分信息。 一般来说&#…

Boom 3D For Win如何进行安装、激活和换机?

Boom系列应用软件又迎来了一位新的“猛将”— 隆重升级的Boom 3D&#xff08;Windows系统&#xff09;&#xff01;这款主打3D环绕音效的软件&#xff0c;既能使用在Windows设备上&#xff0c;也能使用在MAC设备上。Boom 3D既可以让你体验到高质量的3D环绕音效&#xff0c;也能…

分布式幂等问题解决方案

目录 一 背景 二 什么是幂等 三 解决方案三部曲 第一部曲&#xff1a;识别相同请求 第二部曲&#xff1a;列出并减少副作用的分析维度 第三部曲&#xff1a;识别细粒度副作用&#xff0c;针对性设计解决方案 四 总结 一 背景 分布式系统由众多微服务组成&#xff0c;微…

基于嵌入式ARM的工控机与X86工控机的比较

基于嵌入式ARM工控机相对于X86工控机的优点&#xff1a; (1)、功耗&#xff1a;这是ARM工控机最大的优点之一&#xff0c;一般的VIA的X86主板&#xff0c;功耗都在40W左右或者以上&#xff0c;而ARM工控机的功耗极低&#xff0c;DTU系列工控机功耗整体也只有1W左右。 (2)、发热…

docker安装mysql并且进行连接

1、拉取镜像、在linux中执行命令 docker pull mysql 2、运行容器、在linux中执行命令 docker run -d --name mysql -p 3308:3306 -e MYSQL_ROOT_PASSWORD123456 mysql3、 进入容器、在linux中执行命令 docker ps -a docker exec -it 2a85f05d4090 /bin/bash 4、登录docker中的m…

uniapp 详细封装缓存定时过期方法,详细使用过程

最近在开发一个uniapp的项目&#xff0c;中间我们需要给缓存定时&#xff0c;为了解决这个问题&#xff0c;封装了一个方法用来解决这个问题&#xff0c;当时遇到这个问题是因为在项目中要给阿里的OSS上传文件&#xff0c;上传之间先要向服务端请求获取授权&#xff0c;授权我们…

4.28 poll API介绍及代码编写

4.28 poll API介绍及代码编写 #include <poll.h> struct pollfd{int fd;//委托内核检测的文件描述符short events;//委托内核检测文件描述符的什么事件short revents;//文件描述符实际发生的事件 }; int poll(struct pollfd *fds,nfds_t nfds,int timeout);-参数&#x…

Learning C++ No.29 【右值引用实战】

引言&#xff1a; 北京时间&#xff1a;2023/6/7/9:39&#xff0c;上午有课&#xff0c;且今天是周三&#xff0c;承接之前博客&#xff0c;今天我又去帮我舍友签到早八&#xff0c;但愿这次不会被发现吧&#xff01;嘻嘻嘻&#xff01;并且刚刚发文有关对C11相关知识&#xf…

第八章 图像压缩

文章目录 第八章 图像压缩8.1基础知识8.1.1 编码冗余8.1.4图像信息的度量8.1.5保真准则8.1.6图像压缩模型8.17图像格式、容器和压缩标准 8.2一些基本的压缩方法8.2.1霍夫曼编码8.2.2Golomb编码8.2.3算术编码8.2.4LZW编码8.2.5行程编码8.2.6基于符号的编码8.2.7比特平面编码8.2.…

WebGIS 信息系统-系统实现

WebGIS 信息系统-系统实现 主界面基本模块地图基本管理模块地图属性主界面大纲视图实现创建选项菜单添加点击事件实现加载底图图层和定位图层完善这个类文件 主界面基本模块 (1 &#xff09;平移&#xff1a;单击按钮将鼠标置于平移状态&#xff0c;可用来清除当前图形操作工具…

人工智能 | 技能人才评价证书分析及人工智能/计算机类证书推荐

目录 简介技能人才评价证书相关介绍1. 国家职业资格证书2. 职业技能等级证书 推荐证书目录1. 计算机类的国家职业资格证书a. 证书推荐b. “软高***”和“PMP”的区别 2. 计算机类的职业技能等级证书a. 工信部认证b. 中国人工智能学会证书 专业证书的作用1. 抵税2. 领取职业技能…

全志V3S嵌入式驱动开发(USB camera驱动)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 soc和mcu的一个重要区别&#xff0c;就是soc会涉及到大量的音视频操作&#xff0c;当然音视频也就包括了camera摄像头这部分。v3s本身支持csi接口和…

ChatGPT:开放AI平台的最新进展和功能

第一章&#xff1a;引言 在过去的几年中&#xff0c;人工智能技术取得了长足的发展&#xff0c;其在各个领域的应用也日益广泛。而在AI技术中&#xff0c;自然语言处理&#xff08;NLP&#xff09;一直是备受关注的领域之一。ChatGPT作为OpenAI的开放AI平台上的一项重要技术&am…

慕课:笔记

课程链接&#xff1a;直面JavaScript中的30个疑难杂症_JavaScript面试题-慕课网 第二章&#xff1a;数据类型 数据类型是每门编程语言的必修之课&#xff0c;你是否对JavaScript的数据类型和检测存在困惑&#xff0c;本章节将为你揭晓其中的奥秘&#xff0c;让你对数据类型有…

【Tableau案例】神奇宝贝属性及实力强弱|数据可视化

提前声明&#xff1a;神奇宝贝的数据分析仅供参考&#xff0c;不涉及对于神奇宝贝的各种评价&#xff0c;另外我是初学tableau&#xff0c;涉及到使用的tableau操作可能很简单&#xff0c;复杂的还掌握不熟练&#xff0c;之后会拿时间系统学习tabelau。 数据预处理 该数据集有…

CODESYS模拟量超限报警功能块

博途PLC模拟量超限报警功能块详细介绍请参看下面文章链接: PLC模拟量超限报警功能块_RXXW_Dor的博客-CSDN博客模拟量偏差报警功能块请参看下面文章:模拟量偏差报警功能块(SCL代码)_RXXW_Dor的博客-CSDN博客工业模拟量采集的相关基础知识,可以查看专栏的系列文章,这里不再赘…

OSPF故障定位没思路?照这篇抄就行

我的网工朋友大家好。 好久没聊OSPF技术了&#xff0c;相关基础且经典的内容&#xff0c;公众号陆陆续续分享过一些&#xff0c;趣味科普&#xff0c;面试考题&#xff0c;实验操作&#xff0c;都有涉及。 按照惯例&#xff0c;先给你整一波优质的往期内容&#xff1a; 《 5个…

Spring Boot之静态资源映射 | 超级详细,建议收藏

写在前面&#x1f525; 上几期&#xff0c;我们重点讲解了Spring Boot集成Swagger-UI实现在线API文档及美化UI界面&#xff0c;而这期&#xff0c;在 Web 应用中会都会涉及到大量的静态资源&#xff0c;例如 图片、JS、CSS 和 HTML 等。我们知道&#xff0c;Spring MVC 导入静态…

WebGIS 信息系统-主界面基本模块功能设计

文章目录 系统文件夹结构主界面地图基本管理模块功能设计手机定位模块功能设计经纬度路径生成功能设计导航模块功能设计用户管理模块功能设计 系统文件夹结构 为了使项目容易管理和维护&#xff0c;在开发之前需要确定项目的系统文件夹结构&#xff0c;即系统文件夹结构设计。…

C++ / QT 旅游产品管理系统

一、项目介绍 旅游产品管理系统 你是一家旅行社的 IT 主管&#xff0c;现在需要你设计并实现一个旅游产品管理系统。 1 &#xff09; 基本功能要求 * 实现基础界面&#xff1a; 参照现有的旅游产品管理系统&#xff1a;查看产品、选择产品、使用说明等内容 * 支持旅游产品…