码迷,mamicode.com
首页 > 数据库 > 详细

SQL中join的用法

时间:2018-08-18 18:33:52      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:9.png   nat   tween   常见   过滤   性能   直接   没有   insert   

直接举例说明各种方法:

技术分享图片
CREATE table A
(
id int,
name varchar(200)
)
CREATE table b
(
id int,
name varchar(200)
)

INSERT INTO b VALUES(1,‘张三‘)
INSERT INTO b VALUES(2,‘李四‘)
INSERT INTO b VALUES(3,‘王五‘)
INSERT INTO b VALUES(4,‘马六‘)
INSERT INTO b VALUES(5,‘冯七‘)

INSERT INTO a VALUES(1,‘赵八‘)
INSERT INTO a VALUES(2,‘张三‘)
INSERT INTO a VALUES(3,‘冯七‘)
INSERT INTO a VALUES(4,‘田九‘)
INSERT INTO a VALUES(5,‘凌十‘)
技术分享图片

第一种:Inner join

解释:产生的结果是A和B的交集(相同列里面的相同值)。内连接是最常见的一种连接,它也被称为普通连接,只连接匹配的行(仅对满足连接条件的CROSS中的列)。它又分为等值连接(连接条件运算符为"=")和不等值连接(连接条件运算符不为"=",例如between...and)。

SELECT *FROM b INNER JOIN A
on b.name=A.name

技术分享图片

第二种:Full Outer Join

解释:产生的结果是A和B的并集(如果没有相同的值会用null作为值)。FULL JOIN 会从左表和右表那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替

SELECT * FROM b FULL OUTER JOIN A
on b.name=A.name

技术分享图片

第三种:Left outer join

解释:产生表B的完全集,而A表中匹配的则有值(没有匹配的则以null值取代)。LEFT JOIN返回左表的全部行和右表满足ON条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用NULL代替。

SELECT * FROM b Left outer join A
on b.name=A.name

技术分享图片

第四种:Right Outer Join

解释:参考第三种Left outer join

SELECT * FROM b Right Outer Join A
on b.name=A.name

技术分享图片

第5种:cross join

解释:cross对两个表执行笛卡尔乘积。它为左表行和右表行的每种可能的组合返回一行。返回(左表行数*右表行数)行的表。ps:很少用到这个语法。注意如果不是使用嵌套的select语句,一般系统都会产生笛卡尔乘积然再做过滤。这是对于性能来说是非常危险的,尤其是表很大的时候。

SELECT * FROM b  cross join A

技术分享图片

特殊:Natural Join(oracle的用法,sqlserver里面不支持这种写法。ps:大神可以纠正用法这里)

解释:自然连接是一种特殊的等值连接,在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。

SQL中join的用法

标签:9.png   nat   tween   常见   过滤   性能   直接   没有   insert   

原文地址:https://www.cnblogs.com/williamjie/p/9498039.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
分享档案
周排行
mamicode.com排行更多图片
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!