连接查询
本文最后更新于 194 天前,其中的信息可能已经有所发展或是发生改变。

连接查询

内连接

内连接:相当于查询A、B交集部分数据

1). 隐式内连接


SELECT 字段列表 FROM 表1 , 表2 WHERE 条件 ... ;

案例:

查询每一个员工的姓名 , 及关联的部门的名称 (隐式内连接实现)

表结构: emp , dept

连接条件: emp.dept_id = dept.id


select emp.name , dept.name from emp , dept where emp.dept_id = dept.id ;
 -- 为每一张表起别名,简化SQL编写
 select e.name,d.name from emp e , dept d where e.dept_id = d.id;
 == 起别名,不能通过表名限定字段 ==


2). 显式内连接(inner join)


SELECT 字段列表 FROM 表1 [ INNER ] JOIN 表2 ON 连接条件 ... ;

案例同上:

表结构: emp , dept

连接条件: emp.dept_id = dept.id

 select emp.name, dept.name from emp e inner join dept d on e.dept_id = d.id;
 
 -- 为每一张表起别名,简化SQL编写
 
select e.name, d.name from emp e join dept d on e.dept_id = d.id;
 

注意

一旦为表起了别名,就不能再使用表名来指定对应的字段了,此时只能够使用别名来指定字段

外连接

1.左外连接

左外连接相当于查询表1(左表)的所有数据,当然也包含表1和表2交集部分的数据。


SELECT 字段列表 FROM 表1 LEFT [ OUTER ] JOIN 表2 ON 条件 ... ;
 

案例:

查询emp表的所有数据, 和对应的部门信息

由于需求中提到,要查询emp的所有数据,所以是不能内连接查询的,需要考虑使用外连接查询。

注意需求来判断使用内外连接

表结构: emp, dept

连接条件: emp.dept_id = dept.id


select e.*, d.name from emp e left outer join dept d on e.dept_id = d.id;
 
 select e.*, d.name from emp e left join dept d on e.dept_id = d.id;
 

2.右外连接

右外连接相当于查询表2(右表)的所有数据,当然也包含表1和表2交集部分的数据。


SELECT 字段列表 FROM 表1 RIGHT [ OUTER ] JOIN 表2 ON 条件 ... ;
 

案例:

查询dept表的所有数据, 和对应的员工信息(右外连接


select d.*, e.* from emp e right outer join dept d on e.dept_id = d.id;
 
 select d.*, e.* from dept d left outer join emp e on e.dept_id = d.id;

细节与注意点

左外连接和右外连接是可以相互替换的,只需要调整在连接查询时SQL中,表结构的先后顺 序就可以了。而我们在日常开发使用时,更偏向于左外连接。

自连接

自连接查询,顾名思义,就是自己连接自己,也就是把一张表连接查询多次。

 SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ... ;

案例:

查询员工 及其 所属领导的名字

表结构: emp


select a.name , b.name from emp a , emp b where a.managerid = b.id;

查询所有员工 emp 及其领导的名字 emp , 如果员工没有领导, 也需要查询出来

表结构: emp a , emp b

 select a.name '员工', b.name '领导' from emp a left join emp b on a.managerid = 
 b.id;

注意

在自连接查询中,必须要为表起别名,要不然我们不清楚所指定的条件、返回的字段,到底 是哪一张表的字段。

暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇