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是返回所有的值

相关推荐
prince054 小时前
用户积分系统怎么设计
java·大数据·数据库
原来是猿6 小时前
MySQL【内置函数】
数据库·mysql
難釋懷6 小时前
Redis分片集群插槽原理
数据库·redis·缓存
96776 小时前
理解IOC控制反转和spring容器,@Autowired的参数的作用
java·sql·spring
冷小鱼6 小时前
pgvector 向量数据库完全指南:PostgreSQL 生态的 AI 增强
数据库·人工智能·postgresql
陈天伟教授7 小时前
人工智能应用- 天文学家的助手:08. 星系定位与分类
前端·javascript·数据库·人工智能·机器学习
yunyun321237 小时前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
m0_662577977 小时前
高级爬虫技巧:处理JavaScript渲染(Selenium)
jvm·数据库·python
ℳ๓₯㎕.空城旧梦7 小时前
Python单元测试(unittest)实战指南
jvm·数据库·python
Navicat中国7 小时前
Navicat 高效破解 SQL 编写繁琐难题,提升数据库设计效率
数据库·可视化·sql编写繁琐