1. 程式人生 > >SQL語句(inner join,left out join,right out join三者的不同用法)

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規則定的書寫方式,其實這兩個是一樣的。
看了就明白了