sql中的left join, right join 和inner join,union 与union all的用法

left join, right join 和inner join:这些都是SQL中用来连接两个或多个表的操作。

union,union all:用于合并两个或多个 SELECT 语句的结果。

但是有时候,对于Select出来的结果集不是很清楚。

假设我们有两张表。person表是左边的表。address是右边的表。我们分别用inner join,left join和right join,去验证select的结果集到底有什么区别。

1.inner join,也称内连接,我们写出来的sql如下:

bash 复制代码
select * from test.person p inner join test.address a on a.personID = p.personId 

这条sql的查询结果是:

由此可见,返回的结果行是连接条件为真的行 。如果连接条件没有匹配行,那么返回的结果,就会是空的。

2.left join,也称左连接,给定下面sql语句:

bash 复制代码
select * from test.person p left join test.address a on a.personID = p.personId 

这条sql的查询结果是:

可以从结果中看到,返回了person表中所有的行,以及address表匹配的行,如果address表中没有匹配的行,则返回NULL。可以总结为:select结果集是返回左边表中的所有行,以及与右边表匹配的行,如果右边表中没有匹配的行,则返回NULL

3.right join,也称右连接,顾名思义,用法与左连接是相似的。依旧给定语句:

bash 复制代码
select * from test.person p right join test.address a on a.personID = p.personId 

这条sql的查询结果是:

可以从结果中看到,返回了address表中所有的行,以及person表匹配的行,如果person表中没有匹配的行,则返回NULL。可以总结为:select结果集是返回右边表中的所有行,以及与左边表匹配的行,如果左边表中没有匹配的行,则返回NULL

4.union和union all

与上面三个不同的是,union和 union all内部的 select语句必须拥有相同数量的列,并且列的顺序必须相同,同时,列也必须拥有相似的数据类型

比如给定以下两条sql:

bash 复制代码
select personID from test.person
bash 复制代码
select personID from test.address

使用union时的结果如下:

bash 复制代码
select personID from test.person 
union
select personID from test.address

使用union all时的结果如下:

bash 复制代码
select personID from test.person 
union all
select personID from test.address  

由此可见,union是选取不同值 返回。union all是返回所有的值

相关推荐
若兰幽竹28 分钟前
【从零开始编写数据库:基于Python语言实现数据库ToyDB的ACID特性】
数据库·python
宇钶宇夕30 分钟前
S7-200 SMART CPU 密码清除全指南:从已知密码到忘记密码的解决方法
运维·服务器·数据库·程序人生·自动化
周杰伦的稻香38 分钟前
MySQL密码管理器“mysql_config_editor“
数据库·mysql
云朵大王42 分钟前
SQL 视图与事务知识点详解及练习题
java·大数据·数据库
czhc11400756631 小时前
LINUX712 MYSQL;磁盘分区;NFS
数据库·mysql·adb
不太可爱的大白2 小时前
Mysql:分库分表
数据库·mysql
十五年专注C++开发2 小时前
hiredis: 一个轻量级、高性能的 C 语言 Redis 客户端库
开发语言·数据库·c++·redis·缓存
bianguanyue4 小时前
SQLite密码修改故障排查:RSA加密随机性导致的数据库匹配问题
数据库·sqlite·c#
亚马逊云开发者4 小时前
将 Go 应用从 x86 平台迁移至 Amazon Graviton:场景剖析与最佳实践
linux·数据库·golang
张先shen5 小时前
亿级流量下的缓存架构设计:Redis+Caffeine多级缓存实战
数据库·redis·缓存