MySQL基础篇 - 多表查询

server/2024/10/9 15:23:28/

01 多表关系

【1】概念:项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各表结构之间也存在着各种联系,基本上分为三种:一对多(多对一),多对多(要建立中间表),一对一。

02 多表查询概述

【1】概念:多表查询就是指在多张表中查询数据

【2】如果直接查询有多表关系的表:

         例如:select * from emp , dept; 则查询出来的结果将是两张表的笛卡尔积个数据。

         但其实我们只需要一些数据,则此时我们可以通过外键关系在where里面写上条件即可(消除无效笛卡尔积)

         例如:select * from emp , dept where emp.dept_id = dept.id;

【3】多表查询的分类:

03 内连接

【1】内连接:查询两个表有外键关联的数据,如果子表中某个外键数据没有与父表主键关联的值则不会被查出来。

【2】分类:

   ① 隐式内连接:select 字段列表 from 表1 as 别名,表2 as 别名 where 外键关系;

   ② 显示内连接:select 字段列表 from 表1 as 别名 inner join 表2 as 别名 on 外键关系;

【说明】:在多表查询时,我们通常会给表取别名,注意:一旦我们给表取别名后不能再直接使用表名了。

04 外连接

【1】左外连接:查询表1的数据,以及表1和表2交集部分的数据。

【2】右外连接:查询表2的数据,以及表1和表2交集部分的数据。

【3】分类:外连接:如果子表中某个外键数据没有与父表主键关联的值也会被查出来。

   ① 左外连接:select 字段列表 form 表1 as 别名 left outer join 表2 as 别名 on 外键关系;

   ② 右外连接:select 字段列表 form 表1 as 别名 right outer join 表2 as 别名 on 外键关系;

【4】说明:下图案例中很好的说明了:

         内连接:如果子表中某个外键数据没有与父表主键关联的值则不会被查出来。

         外连接:如果子表中某个外键数据没有与父表主键关联的值也会被查出来。

05 自连接

【1】场景:表中的外键关联的是自己所在表的某个字段,例如:查询某个员工的领导,而领导也是员工。

【2】语法:其实就是利用取别名,把一张表看成两张表,可以内查询也可以外查询。

    ① 内连接(隐式写法):select 字段列表 form 表一 别名,表一 别名 where 外键关系;

    ② 外连接(左外连接):select 字段列表 from 表一 别名 left outer join 表一 别名 on 外键关系;

06 联合查询

【1】概念:union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。

【2】注意:

   ① 对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

       (比如查多张成绩单上满足某条件的数据,然后把它合并起来形成一张表)

   ② union all会将全部的数据直接合并在一起,union会对合并之后的数据去重。

【3】语法:

         select 字段列表 from 表a ...

         union all/union

         select 字段列表 from 表b ...

07 子查询

【1】概念:SQL语句中嵌套select语句,称为嵌套查询,即子查询。

【2】子查询外部的语句可以是insert/update/delete/select的任何一个,select会用得多一些。

【3】举例:select * from t1 where column1 = (select column1 from t2)

【4】分类:根据子查询的结果分为:

   ① 标量子查询(子查询结果为单个值)

   ② 列子查询(子查询结果为一列)

   ③ 行子查询(子查询结果为一行)

   ④ 表子查询(子查询结果为多行多列)

【5】根据子查询位置,分为:where之后,form之后,select之后。

07_01 标量子查询

【1】标量子查询:子查询返回的查询结果是单个值(数字,字符串,日期等)

【2】标量子查询中常用的操作符:=,<>,>,>=,<,<=

07_02 列子查询

【1】列子查询:子查询的结果是一列(可以是多行)

【2】列子查询中常用的操作符:in,not in,any,some,all

【3】in是只要满足其中的一种,any是只要=,<>,>,>=,<,<= 其中一种

07_03 行子查询

【1】行子查询:返回的结果是一行(可以是多列)

【2】行子查询中常用的操作符:=,<>,in,not in

【3】注意:a = 12 && b = 13 可以写成 (a, b)= (12, 13),因此下图示例中的写法才是那样。

07_04 表子查询

【1】表子查询:返回的结果是多行多列的。

【2】表子查询常用的操作符:in


http://www.ppmy.cn/server/126355.html

相关文章

数据结构-3.8.栈在括号匹配中的应用

一.括号匹配问题&#xff1a; 1.例一&#xff1a; 把左括号依次压入栈中&#xff0c;越往后压入栈的左括号越先被匹配即被弹出栈->先进后出&#xff0c;后进先出 2.例二&#xff1a; 当遇到左括号就压入栈中&#xff0c;当遇到右括号就把栈顶的左括号弹出&#xff0c;检查…

void类型

编程语言中的void类型是一种特殊的数据类型&#xff0c;它表示不存在任何值。void, 无或者空类型。大部分编程语言支持void, 用做函数无返回值类型。最早ALGOL 68引入void类型。 void的特别使用 经典C缺乏void类型&#xff0c;函数可以不指定返回值&#xff0c;默认是整型int.…

MacOS多桌面调度快捷键

单桌面调度快捷键 可能是我用着妙控鼠标用着不习惯&#xff0c;所以追求快捷键操作&#xff0c;看起来也比较酷。而且在Windows上&#xff0c;我基本不使用多桌面&#xff0c;但是看着同事用Mac的多桌面用的飞起&#xff0c;炫酷程度不亚于win7的Windows键Tab。在不使用多桌面的…

MySQL基础练习题49-低质量的问题

目录 题目 准备数据 分析数据 总结 题目 找出 低质量 问题的 ID 集合。如果一个力扣问题的喜欢率&#xff08;喜欢数除以总投票数&#xff09;严格低于 60% &#xff0c;则该问题为低质量问题。 按 problem_id 升序排列返回结果表。 准备数据 Create table If Not Exis…

创建Vue项目的时出现:无法加载文件 E:\software\node\node_global\vue.ps1,因为在此系统上禁止运行脚本

创建Vue项目的时出现的问题:出现&#xff1a;无法加载文件 E:\software\node\node_global\vue.ps1&#xff0c;因为在此系统上禁止运行脚本 解决方法&#xff1a; .PowerShelll的执行政策阻止了该操作,用 get-ExecutionPolicy 查看执行策略的状态为受限 输入Set-ExecutionPo…

Java面试——操作系统篇

1.进程线程的区别 定义&#xff1a; 进程&#xff1a;进程是操作系统进行资源分配和调度的一个独立单位。它是应用程序运行的实例&#xff0c;拥有独立的内存空间。线程&#xff1a;线程是进程中的一个实体&#xff0c;是被系统独立调度和分派的基本单位。线程自身基本上不拥有…

element-ui 通过按钮式触发日期选择器

element ui 写在前面1. 自定义的日期时间组件CustomDatePicker.vue2. 页面效果总结写在最后 写在前面 需求&#xff1a;elementui中日期时间选择器&#xff0c;目前只能通过点击input输入框触发日期选择器&#xff0c;我希望能通过其他方式触发日期选择器同时把input输入框去掉…

Thinkphp/Laravel基于Vue的重庆旅游网站交互设计与实现

目录 系统介绍具体实现截图技术栈和环境说明开发技术简介解决的思路性能/安全/负载方面数据访问方式PHP核心代码部分展示代码目录结构解析系统测试详细视频演示获取源码方式 系统介绍 本系统的设计与实现共包含12个表:分别是关于我们信息表&#xff0c;配置文件信息表&#xf…