数据库第五弹

连接查询

内连接

内连接:相当于查询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;

注意

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

联合查询

对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。

对于联合查询的多张表的列数必须保持一致,字段类型也需要保持一致。

union all 会将全部的数据直接合并在一起,union 会对合并之后的数据去重。

 SELECT 字段列表 FROM 表A ... 
 ​
 UNION [ ALL ]
 ​
 SELECT 字段列表 FROM 表B ....;
 ​

案例:

将薪资低于 5000 的员工 , 和 年龄大于 50 岁的员工全部查询出来.

 select * from emp where salary < 5000
 ​
 union all
 ​
 select * from emp where age > 50;
 ​
 1.使用union可以去重,使用union all 知识把查询出来的结果合并了
 2.两个select语句查询字段不同将会报错,例 第一个select *。。。。,select name 。。。。。
暂无评论

发送评论 编辑评论


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