SQL语句(inner join,left out join,right out join三者的不同用法)

left join   :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。
right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。
inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。
full join:外连接,返回两个表中的行:left join + right join
cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。

declare @a table(a int,b int)
declare @b table(a int,b int)

insert @a values(1,1)
insert @a values(2,2)
insert @b values(1,1)
insert @b values(3,3)
select * from @a 
select * from @b
--左:
select * from @a Aa left join @b Bb on Aa.a=Bb.a
--右:
select * from @a Aa right join @b Bb on Aa.a=Bb.a
--内
select * from @a Aa inner join @b Bb on Aa.a=Bb.a
--外:
select * from @a Aa full join @b Bb on Aa.a=Bb.a
--交叉连接
select * from @a  cross join @b
 
select * from a,b where a.id=b.id ---等值连接
select * from a inner join b on a.id = b.id -----内连接
内连接与等值连接效果是相同的,执行效率也是一样的。
只不过内连接是由SQL 1999规则定的书写方式,其实这两个是一样的。
看了就明白了

你可能感兴趣的:(SQL语句(inner join,left out join,right out join三者的不同用法))