mysql多表查询

1、 笛卡尔积与隐式内连接

对select * fom emp,dept;所返回的结果集遵循笛卡尔积运算;

为了消除冗余的笛卡尔积;我们需要使用where x 例如

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

其实这是一种隐式内连接。

2、 多表查询分类

我们可以将多表查询分成: 内连接,外连接,自连接等。

3、 内连接的两种写法

内连接有隐式内连接和显示内连接

隐式内连接FROM 表1, 表2 WHERE 条件,写法简洁,但在表较多时可读性稍差。

显式内连接FROM 表1 INNER JOIN 表2 ON 条件,使用 INNER JOIN 关键字,逻辑更清晰,推荐在复杂查询中使用。

4、 外连接的实战经验

对于外连接,我们可以分为左外连接和右外连接

实际上在实际开发,我们只focus on左外就可以了(右外也可调成左外嘛)

使用的语法是:

from 表1 left join 表2 on 条件

结果和表1的数据量是一样的,例如表1有n条数据,左外连接的结果就有n条数据

**即左外连接(LEFT JOIN)保证左表的所有数据都被返回,右表没有匹配的则用 NULL 填充,这在业务中最常用,**比如 "查询所有员工及其所属部门,包括没有部门的员工"。

5、 自连接

它将同一张表通过别名的方式当作两张不同的表来使用,从而实现对表中数据的关联查询。

1、必须使用表别名 因为是同一张表进行连接,必须用别名(如 a 和 b)来区分 "两张表",否则数据库无法识别你要引用的是哪一部分的数据。

2、既可以是内连接,也可以是外连接

3、例子:

1)需求:查询员工及其直属领导的名字(只查询有领导的员工)

SELECT a.name, b.name FROM emp a, emp b WHERE a.managerid = b.id;

这是一个隐式内连接,只会返回那些有领导(即 managerid 不为空)的员工。

2)需求:查询所有员工及其领导的名字,包括没有领导的员工

SELECT a.name '员工', b.name '领导' FROM emp a LEFT JOIN emp b ON a.managerid = b.id; 因为要忙组左表的数据全都被返回,所以使用左外连接。

左表是员工表,右表是领导表。 如果某个员工没有领导(managerid 为 NULL),那么 b.name 这一列就会显示为 NULL。

联合查询

一、联合查询是一种将多个 SELECT 查询的结果集纵向合并成一个大结果集的查询方式,它的核心作用是实现 "多表同构数据的合并展示"。

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

2、列名由第一个查询决定 最终结果集的列名,由第一个 SELECT 语句中的字段名决定,后续查询的列名会被忽略。

二、UNION vs UNION ALL

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

正因为union要去重,需要额外的排序和比较,性能较低 适用于当你需要确保结果集中没有重复数据时。

2、例子:

假设我们有两张结构相同的表:emp_2024(2024 年员工)和 emp_2025(2025 年员工)。|

sql 复制代码
SELECT name, salary FROM emp_2024
UNION ALL
SELECT name, salary FROM emp_2025;
相关推荐
科技小花4 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56615 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全6 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717216 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣5477 小时前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
小江的记录本7 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi7 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai7 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw07 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209258 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql