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

相关推荐
正在走向自律6 小时前
金仓数据库KingbaseES中级语法详解与实践指南
数据库·oracle·kingbasees·金仓数据库·信创改造
Gofarlic_oms16 小时前
Windchill用户登录与模块访问失败问题排查与许可证诊断
大数据·运维·网络·数据库·人工智能
我是小疯子666 小时前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
Zoey的笔记本7 小时前
2026告别僵化工作流:支持自定义字段的看板工具选型与部署指南
大数据·前端·数据库
静听山水7 小时前
docker安装starrocks
数据库
学编程的小程8 小时前
从“兼容”到“超越”:金仓KESBSON引擎如何借多模融合改写文档数据库规则
数据库
千层冷面8 小时前
数据库分库分表
java·数据库·mysql·oracle
DBA小马哥8 小时前
金仓数据库引领国产化替代新范式:构建高效、安全的文档型数据库迁移解决方案
数据库·安全·mongodb·dba·迁移学习
企业对冲系统官9 小时前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划
冉冰学姐9 小时前
SSM学毕电设信息采集系统74v6w(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理·ssm 框架应用·学毕电设·信息采集系统