总结:内连接,左(右)外连接,全外连接,交叉连接。
1.内连接(INNER JOIN/JOIN)。显示符合条件的记录。不符合的记录不显示。
2.左外连接、右外连接(LEFT OUTER JOIN/RIGHT OUTER JOIN)。用于显示符合条件的数据行以及左(右)边表不符合条件的数据航,另外一边的数据则会以NULL显示。
3.全外连接(FULL OUTER JONI)。显示符合条件的数据行以及两边不符合数据的数据航,不符合的数据会以NULL显示。
4.交叉连接(CROSS JOIN)。将一个表的每一个记录与另一个表的每个记录匹配成新的数据行(一共会有M*N行)。
如表
------------------------------------------------- table1 | table2 | ------------------------------------------------- id name |id score | 1 lee |1 90 | 2 zhang |2 100 | 4 wang |3 70 | ------------------------------------------------- 以下均在查询分析器中执行 一、外连接 1.概念:包括左向外联接、右向外联接或完整外部联接 2.左连接:left join 或 left outer join (1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。 (2)sql语句 select * from table1 left join table2 on table1.id=table2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 4 wang NULL NULL ------------------------------ 注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示 3.右连接:right join 或 right outer join (1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。 (2)sql语句 select * from table1 right join table2 on table1.id=table2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 NULL NULL 3 70 ------------------------------ 注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示 4.完整外部联接:full join 或 full outer join (1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。 (2)sql语句 select * from table1 full join table2 on table1.id=table2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 4 wang NULL NULL NULL NULL 3 70 ------------------------------ 注释:返回左右连接的union(见上左、右连接) 二、内连接 1.概念:内联接是用比较运算符比较要联接列的值的联接 2.内连接:join 或 inner join 3.sql语句 select * from table1 join table2 on table1.id=table2.id -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 2 100 ------------------------------ 注释:只返回符合条件的table1和table2的列 4.等价(与下列执行效果相同) A:select a.*,b.* from table1 a,table2 b where a.id=b.id B:select * from table1 cross join table2 where table1.id=table2.id (注:cross join后加条件只能用where,不能用on) 三、交叉连接(完全) 1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录) 2.交叉连接:cross join (不带条件where...) 3.sql语句 select * from table1 cross join table2 -------------结果------------- id name id score ------------------------------ 1 lee 1 90 2 zhang 1 90 4 wang 1 90 1 lee 2 100 2 zhang 2 100 4 wang 2 100 1 lee 3 70 2 zhang 3 70 4 wang 3 70 ------------------------------ 注释:返回3*3=9条记录,即笛卡尔积 4.等价(与下列执行效果相同) A:select * from table1,table2转自:http://323229113.blog.163.com/blog/static/2185362820070172553209
分享到:
相关推荐
SQL优化--使用内连接(inner join)代替外连接(left join,right join)
主要讲述了使用select进行内、外连接查询的内容
sql左外连接、右外连接、内连接、全外连接的区别
关于内连接,外连接(左右连接)等的总结关于内连接,外连接(左右连接)等的总结关于内连接,外连接(左右连接)等的总结
SQL 左外连接,右外连接,全连接,内连接 四种连接的差异
通常在项目中对表的查询都是关联多张表,多表查询就涉及到sql的内连接、外连接和自连接查询。本篇文章将简单的介绍这些sql连接的使用,希望对大家有所帮助。
SQL 左外连接,右外连接,全连接,内连接 。联接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定联接条件。WHERE和HAVING子句也可以包含搜索条件,以进一步筛选联接条件所选的行。
SQL基本SELECT查询语句_内外连接
SQL 内连接,外连接:假设一堆男女在教堂,有夫妇有单身的,假设男为左表,女为右表......
SQL左外连接,右外连接,全连接,内连接四种连接的差异[参照].pdf
SqlServer连接工具SqlServer连接工具SqlServer连接工具
学习内连接和外连接的实例,可以很直观的看到他们的区别。
SQL 连接 JOIN 例解左连接,右连接,全连接,内连接,交叉连接,自连接
SQL内连接与外连接.pdfSQL内连接与外连接.pdfSQL内连接与外连接.pdfSQL内连接与外连接.pdfSQL内连接与外连接.pdfSQL内连接与外连接.pdf
SQL连接JOIN例解 (左连接,右连接,全连接,内连接,交叉连接,自连接)pdf
sql内连接、外连接,左右联合查询。通过一些简单的例子,最后发现其实联合查询很简单的^ ^
sql左连接,右连接,内连接,全连接详细讲解
SQLTools sql连接工具SQLTools sql连接工具SQLTools sql连接工具
ASP连接SQL2005数据库连接代码
SQL内连接与外连接.doc