SQL连接查询研究

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL连接查询研究相关的知识,希望对你有一定的参考价值。

参考技术A 1、分类
在多表关联查询时,经常要用到连接查询,SQL中连接分为四种:内连接(inner join或join)、左外连接(left outer join)、右外连接(right outer join)、全连接(full outer join);
其中,除了inner join其余三种都是外连接。
首先建2张表用于后面的讲解用。
表A:合同表

表B:合同金额历史修改记录表

其中,B表中的fk_contract_id字段与A表中的id字段有外键关系;
2、inner join内连接
内连接结果返回A、B两个表均匹配的数据集,其中有一个表的数据不满足,则那条数据不返回;
模拟数据如下:
A:

B:

结果:

分析:

3、left outer join左外连接
通常也简称为左连接,sql中可省略outer,写为:left join;
左连接以左表为主表,右表为从表,返回结果集以左表数据为基础,连接右表获取额外信息;
查询语句举例:

结果:

分析:
从结果可以看出,虽然合同3在B表中没有数据与之对应,但是还是作为结果集中的一部分返回了,因此可以这么说,只要主表有N条记录,使用left join查询返回的结果集一定至少有N条记录(不考虑where条件)!

特别注意左连接时查询条件放置的位置:
使用left join查询时,主表的筛选条件要放在where中,而从表的条件要看情况选择放在连接条件on中或是放在where中;下面举例子说明这两种情况:
栗子1:查询出所有历史合同金额有过300的合同记录。
sql:

结果:

结果满足我们的需求,但是如果把筛选条件放在on中:

结果:

显然,查询结果不满足我们的这个需求!
栗子2:查询出所有合同,并且如果其历史合同金额有过300则展示其合同记录信息。
在这个需求下,我们把查询条件放在on中就是正确的,这时是不能放在where中的。
4、right outer join右外连接
通常简称为右连接,outer可省略,写为:right join;
与左连接相反,右连接以右表为主表,即以右表记录为基础,扩展查询左表信息;
一般可与左连接相互转换,例如上栗1用右连接可以写成如下sql:

结果:

5、full outer join全连接
全连接,即只要其中某个表存在匹配,full join关键字就会返回行。在mysql中并不支持full join,但可以用left join和right join查询后再union代替,举个栗子:
A表数据:

B表数据:

结果:

分析:
从结果中可以看出,全连接会返回A、B表中所有记录,其中有关联的会根据on条件进行整合,没有连接上的记录也会返回。

总结:
SQL中的连接查询使用非常频繁,但其中的一些细节还需要平时多注意,比如:
1、左、右连接时的条件放置位置及其区别;
2、一对多关系时,在左、右外连接时,若“一”为主表(或内连接)时,查询结果集主表记录会有重复!若要统计主表记录时则需去重。

以上是笔者在平时工作中用到sql的连接查询时总结出来的知识,分享给大家,希望对读者有帮助!如有错误请给我留言,我会及时更正,谢谢!

SQL(之三)-连接查询

上图为个人总结的SQL连接查询。持续更新完善中...

 

以上是关于SQL连接查询研究的主要内容,如果未能解决你的问题,请参考以下文章

SQL 连接查询

sql子查询和连接查询的区别是啥呢?

sql多表连接查询问题

SQL怎么连接查询2个表?

SQL怎么连接查询2个表?

一文让你彻底理解SQL连接查询