sql join详解

inner join(等值连接)

默认join方式,如果不加修饰词
只返回两个表中联结字段相等的行

left join(左连接)

返回包括左表中的所有记录和右表中联结字段相等

right join(右连接)

与左连接相反

full join(全连接)

返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。
即左连接、右连接结果的合并

非等连接

使用等值以外的条件来匹配左、右两个表中的行

select A.c1,B.c2 from A join B on A.c3 != B.c3;

举例说明

表Article和表ArticleComment分别表示“文章”和“文章评论”,ArticleComment有Article外键ArticleId。表设计为:


表Article数据如下:

表ArticleComment数据如下:

需要注意的是,严格来说,任意的ArticleComment都应该有外键ArticleId,这里为了说明join,没有严格要求,ArticleId可以为空。

inner join(等值连接)

select Article.Id,Article.Name,ArticleComment.Id as 'ArticleCommentId',ArticleComment.[Content],ArticleComment.ArticleId 
from Article
join ArticleComment on Article.Id=ArticleComment.ArticleId

结果:

left join(左连接)

select Article.Id,Article.Name,ArticleComment.Id as 'ArticleCommentId',ArticleComment.[Content],ArticleComment.ArticleId 
from Article
left join ArticleComment on Article.Id=ArticleComment.ArticleId

结果:

right join(右连接)

select Article.Id,Article.Name,ArticleComment.Id as 'ArticleCommentId',ArticleComment.[Content],ArticleComment.ArticleId 
from Article
right join ArticleComment on Article.Id=ArticleComment.ArticleId

结果:

full join(全连接)

select Article.Id,Article.Name,ArticleComment.Id as 'ArticleCommentId',ArticleComment.[Content],ArticleComment.ArticleId 
from Article
full join ArticleComment on Article.Id=ArticleComment.ArticleId

结果:

非等连接

select Article.Id,Article.Name,ArticleComment.Id as 'ArticleCommentId',ArticleComment.[Content],ArticleComment.ArticleId 
from Article
join ArticleComment on Article.Id!=ArticleComment.ArticleId

结果:

技巧

Left right join 多表的连接顺序
多表左/右连接,表的连接顺序也可以影响查询速度
左连接时,应该把小表放在前面连接
例子:
A、B、C三表左连接
情况1:
A先和B连接,得到100条记录
100条记录再和C左连接
情况2:
A先和C连接,得到50条记录
50条记录再和B左连接

右连接时,把小表放在后面连接

posted @ 2020-03-10 20:28  Lulus  阅读(2246)  评论(0编辑  收藏  举报