本文摘自PHP中文网,作者coldplay.xixi,侵删。
推荐( 免费):SQL教程
大家在初学数据库时,对DQL中的连接查询是否有些疑惑,不知道什么时候什么场景下该用那种连接查询?
不要着急,接下来由我来给大家介绍一下,本人对内连接、左外连接、右外连接的特点和应用场景的理解,供大家参考。
以下的代码演示均基于name表和country表展开。
name表
id | name |
---|---|
1 | 西施 |
2 | 杨玉环 |
3 | 貂蝉 |
4 | 王昭君 |
5 | 赵飞燕 |
country表
id | country | A_ID |
---|---|---|
1 | 春秋时期越国人 | 1 |
2 | 唐代蒲州永乐人 | 2 |
3 | 东汉末年山西忻州人 | 3 |
4 | 西汉时期南郡秭归人 | 4 |
5 | 战国时期 | 6 |
注 :
1)b表A_ID与a表a_id 存在关系
2)连接查询是要使用关联条件去除不匹配数据否则会出现笛卡尔积
1) 内连接
1 2 3 4 5 6 |
|
1 |
|
id | name | id | country | N_ID |
---|---|---|---|---|
1 | 西施 | 1 | 春秋时期越国人 | 1 |
2 | 杨玉环 | 2 | 唐代蒲州永乐人 | 2 |
3 | 貂蝉 | 3 | 东汉末年山西忻州人 | 3 |
4 | 王昭君 | 4 | 西汉时期南郡秭归人 | 4 |
2)左外连接
1 2 3 4 5 6 |
|
1 |
|
id | name | id | country | N_ID |
---|---|---|---|---|
1 | 西施 | 1 | 春秋时期越国人 | 1 |
2 | 杨玉环 | 2 | 唐代蒲州永乐人 | 2 |
3 | 貂蝉 | 3 | 东汉末年山西忻州人 | 3 |
4 | 王昭君 | 4 | 西汉时期南郡秭归人 | 4 |
5 | 赵飞燕 | null | null | null |
3) 右外连接
1 2 3 4 5 6 7 |
|
1 |
|
id | name | id | country | N_ID |
---|---|---|---|---|
1 | 西施 | 1 | 春秋时期越国人 | 1 |
2 | 杨玉环 | 2 | 唐代蒲州永乐人 | 2 |
3 | 貂蝉 | 3 | 东汉末年山西忻州人 | 3 |
4 | 王昭君 | 4 | 西汉时期南郡秭归人 | 4 |
null | null | 5 | 战国时期 | 6 |
4) 完全链接
1 2 |
|
1 |
|
id | name | id | country | N_ID |
---|---|---|---|---|
1 | 西施 | 1 | 春秋时期越国人 | 1 |
2 | 杨玉环 | 2 | 唐代蒲州永乐人 | 2 |
3 | 貂蝉 | 3 | 东汉末年山西忻州人 | 3 |
4 | 王昭君 | 4 | 西汉时期南郡秭归人 | 4 |
5 | 赵飞燕 | null | null | null |
null | null | 5 | 战国时期 | 6 |
注意:该语法在MySql中不适用
好的,本人介绍完毕,不知道有没有帮助到各位呢?
如果有什么不对,还请各位指出哦~
更多相关知识敬请关注sql栏目~
以上就是理解sql语句的内连接、左外连接、右外连接的详细内容,更多请关注木庄网络博客其它文章!
相关阅读 >>
更多相关阅读请进入《左连接特点》频道 >>
数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。