SQL笔记——左连接、右连接、内连接

前言:总是忘记表连接的区别,在面试的时候也容易被问到,因此就好记性不如烂笔头吧

集合运算

有并集、交集、差集
联合查询 *(针对行合并的)*
union 为关键字,就是将两个select的结果求并集(此时重复的只出现一次,要是想把重复的也都展示出来 应该用 union all)
ps:以上这些是用行进行计算的,而下面的内连接和外连接是用列进行计算的

内连接

只会现实关键字所在的共有的行,各自的独特的行没有,

假如实现a表和b表通过关键字sid来链接起来

a中sid是1~5,b中sid是2-8,那么结果中sid只有2-5.

c 复制代码
select * from a #展示的是a表中的全部
inner join b
on a.sid=b.sid;
###如果结果只展示a中的sid、sex、name列,一定要使用"表名+点+列名"格式,
###如果加上别名,用as,同时还使用where函数则为
select a.sid,a.sex,a.name from a as staff
inner join b as market
on a.sid=b.sid
where b.age>20;

由于内连接会忽略一些结果,但是实际中可能想展示a中的所有sid或者b中的所有sid,则需要其他连接方式,如左外连接or右外连接

外连接

1.左外连接

结果以左表a中为准,sid就是1-5啦,可能1中有些内容是空白,因为b中没有sid=1的内容

c 复制代码
select * from a 
left outer join b
on a.sid=b.sid;

2.右外连接

结果以左表b中为准,sid就是2-8啦,可能5-8中有些内容是空白,因为a中没有sid=6到8的内容

c 复制代码
select * from a 
right outer join b
on a.sid=b.sid;

3.完全连接

就是左连接union有链接,把a和b中全部的展示,有点像就并集

c 复制代码
select * from a
right outer join b
on a.sid=b.sid;
union
select * from a
left outer join b
on a.sid=b.sid;

笛卡尔积

也称交叉连接,有点像排列组合的感觉

像a中有1-3,b中有ijk,

则结果就是1i、1j、1k、2i、2j、2k、3i以此类推

1.笛卡尔积连接

c 复制代码
select 列名
from a,b;
或者是
select 列名
from a cross join b;

2.自连接

就是自己连接自己,但是的区分,用as来重命名

c 复制代码
select 列名
from a as a1,a as a2;

一个例子,自连接实现排序

c 复制代码
select a.name,a.age,count(*) as 排名
from a as a1,a as a2
where a1.age<=a2.age
group by a1.sid
order by 排名;
相关推荐
A-刘晨阳12 分钟前
从MongoDB到金仓:一次电子证照系统的平滑国产化升级实践
数据库·mongodb
瓜瓜怪兽亚18 分钟前
前端基础知识---10 Node.js(三)
数据结构·数据库·node.js
掘根2 小时前
【Qt】常用控件3——显示类控件
开发语言·数据库·qt
码码哈哈爱分享2 小时前
MariaDB 与 MySQL 区别
数据库·mysql·mariadb
爱敲代码的TOM2 小时前
深入MySQL底层1-存储引擎与索引
数据库·mysql
GUIQU.2 小时前
【QT】嵌入式开发:从零开始,让硬件“活”起来的魔法之旅
java·数据库·c++·qt
sz-lcw5 小时前
MySQL知识笔记
笔记·mysql·adb
牛奶咖啡136 小时前
关系数据库MySQL的常用基础命令详解实战
数据库·mysql·本地远程连接到mysql·创建mysql用户和密码·修改mysql用户的密码·设置mysql密码的使用期限·设置和移除mysql用户的权限
古译汉书6 小时前
嵌入式铁头山羊STM32-各章节详细笔记-查阅传送门
数据结构·笔记·stm32·单片机·嵌入式硬件·个人开发
ANYOLY7 小时前
Redis 面试宝典
数据库·redis·面试