博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL - 内连接与外连接
阅读量:6292 次
发布时间:2019-06-22

本文共 3652 字,大约阅读时间需要 12 分钟。

PDF下载地址:

连接查询在关系型数据库中经常用到,是多表联合查询的基础。

主要包含:内连接外连接交叉连接

 


内连接

内连接又分为等值连接不等值连接自然连接

连接查询中使用的比较运算符有:=, >, <, <>, >=, <=, !>, !<

等值连接

等值连接使用”=”来进行比较运算。

请看下面的例子:

student_id student_name class_id
1 aaa 15
2 bbb 16
3 ccc 17

 

class_id class_name
15 五班
16 六班
17 七班
18 八班

如果需要查出一下内容:

每个学生所对应的班级名称

此时就可用以下sql语句:

SELECT * FROM     T_student ts,T_class tc WHERE     ts.class_id=tc.class_id

或者:

SELECT * FROM     T_student ts inner join T_class tc ON     ts.class_id = tc.class_id

查询结果如下:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班

结论如下:

等值连接:

若要连接表t1和t2,比较条件为t1.a=t2.a,那么数据库会用t1中a列的所有元素逐个和t2中的a进行比较,如果相等,则输出该行。

至于数据库内部如何实现,我们暂且不去深究。

不等值连接

内连接中,不使用”=”作为比较运算符,就叫不等值连接。

如果需要查询以下内容:

T_student表和T_class表中,class_id字段不相等的所有组合

此时就可用以下sql语句:

SELECT * FROM     T_student ts,T_class tc WHERE     ts.class_id <> tc.class_id

或者:

SELECT * FROM     T_student ts inner join T_class tc ON     ts.class_id <> tc.class_id

查询结果如下:

student_id student_name class_id class_id class_name
2 bbb 16 15 六班
3 ccc 17 15 七班
1 aaa 15 16 五班
3 ccc 17 16 七班
1 aaa 15 17 五班
2 bbb 16 17 六班
1 aaa 15 18 五班
2 bbb 16 18 六班
3 ccc 17 18 七班

结论如下:

不等值连接

若要连接表t1和t2,比较条件为t1.a不等于t2.a,那么数据库会用t1中a列的所有元素逐个和t2中的a进行比较,如果不相等,则输出该行。

自然连接

自然连接是一种特殊的等值连接,和等值连接差不多,区别在于:

自然连接会去掉重复的列;

自然连接要求比较的两个列属性必须相同,等值连接则不需要;

如果需要查出以下内容:

每个学生所对应的班级名称

sql语句和等值连接差不多:

SELECT ts.*,tc.class_name FROM     T_student ts inner join T_class tc ON     ts.class_id = tc.class_id

查询结果如下:

student_id student_name class_id class_name
1 aaa 15 五班
2 bbb 16 六班
3 ccc 17 七班

由此可见:

自然连接相当于在等值连接的基础上,加了显示的限定条件,从而实现列去重

外连接

外连接又分为左连接右连接全连接

左连接

左连接以左表为基础,显示左表中的所有记录(显示的记录条数=左表中记录的条数)。再用左表中的指定列来和右表中的指定列比较,满足则输出值,不满足则输出NULL

如果需要查出以下内容:

每个学生所对应的班级名称

此时就可用以下sql语句:

SELECT * FROM     T_student ts left join T_class tc ON     ts.class_id = tc.class_id

查询结果如下:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班

但如果T_student表中增加一条字段:

student_id student_name class_id
4 ddd 20

此时再用上一条sql语句查询,则结果变为:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班
4 ddd 20 NULL NULL

结论如下:

左连接

以左表为基础,显示的记录条数=左表中记录条数。如果左表中选出的字段符合条件则显示,否则显示NULL

右连接

与左连接恰恰相反。以右表为基础,显示记录的条数=右表中记录条数,然后和左表中的字段比较,符合条件则输出,否则输出NULL

使用以下sql语句:

SELECT * FROM     T_student ts right join T_class tc ON     ts.class_id = tc.class_id

查询结果为:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班
NULL NULL NULL 18 八班

结论如下:

右连接

以右表为基础,显示记录的条数=右表中记录条数。如果左表中选出的字段符合条件则显示,否则显示NULL

全连接

全连接类似于左连接和右连接的综合,显示记录的条数=指定比较字段在两个表中的不同种类数。对于空余字段则显示NULL

使用以下sql语句:

SELECT * FROM     T_student ts full join T_class tc ON     ts.class_id = tc.class_id

查询结果为:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班
NULL NULL NULL 18 八班

但如果T_student表中增加一条字段:

student_id student_name class_id
4 ddd 20

此时再用上一条sql语句查询,则结果变为:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 16 六班
3 ccc 17 17 七班
4 ddd 20 NULL NULL
NULL NULL NULL 18 八班

结论如下:

全连接

指定比较字段在两个表中的不同种类数。对于空余字段则显示NULL

交叉连接

交叉连接很简单,就是两个表做笛卡尔积

如果不加where做选择比较,那么显示的记录行数就是两个表行数的乘积。
使用以下sql语句:

SELECT * FROM     T_student cross join T_class

或者:

SELECT * FROM     T_student,T_class

查询结果为:

student_id student_name class_id class_id class_name
1 aaa 15 15 五班
2 bbb 16 15 六班
3 ccc 17 15 七班
1 aaa 15 16 五班
2 bbb 16 16 六班
3 ccc 17 16 七班
1 aaa 15 17 五班
2 bbb 16 17 六班
3 ccc 17 17 七班
1 aaa 15 18 五班
2 bbb 16 18 六班
3 ccc 17 18 七班

如果是有where进行选择,那就先进行笛卡尔积,然后在笛卡尔积的结果中进行选择(效率很差)。

结论如下:

交叉连接

没有where进行选择,结果为两个表的笛卡尔积

where进行选择,先做笛卡尔积,在笛卡尔积的结果中进行选择


  • Github:,
  • 邮箱:

 
 

转载于:https://www.cnblogs.com/crazyacking/p/5324909.html

你可能感兴趣的文章
概率论与数理统计习题
查看>>
初学structs2,简单配置
查看>>
Laravel5.0学习--01 入门
查看>>
时间戳解读
查看>>
sbin/hadoop-daemon.sh: line 165: /tmp/hadoop-hxsyl-journalnode.pid: Permission denied
查看>>
@RequestMapping 用法详解之地址映射
查看>>
254页PPT!这是一份写给NLP研究者的编程指南
查看>>
《Data Warehouse in Action》
查看>>
String 源码浅析(一)
查看>>
Spring Boot 最佳实践(三)模板引擎FreeMarker集成
查看>>
Fescar 发布 0.2.3 版本,支持 Redis 和 Apollo
查看>>
Google MapReduce到底解决什么问题?
查看>>
CCNP-6 OSPF试验2(BSCI)
查看>>
Excel 2013 全新的图表体验
查看>>
openstack 制作大于2TB根分区自动扩容的CENTOS镜像
查看>>
Unbuntu安装遭遇 vmware上的Easy install模式
查看>>
几个常用的ASP木马
查看>>
python分析postfix邮件日志的状态
查看>>
Mysql-5.6.x多实例配置
查看>>
psutil
查看>>