以一個實際的例子來理解關聯子查詢
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 |
關聯子查詢效率
很明顯,一般情況下關聯子查詢的效率是比較低下的,實際上本例中的關聯子查詢例子也僅是為了示範關聯子查詢的原理及用法。如果可以的話,關聯子查詢盡量使用 JOIN 或其他查詢來代替。如本例中,使用 INNER JOIN 來替換的 SQL 為:
| 代碼如下 |
複製代碼 |
SELECT article.* FROM article INNER JOIN user ON article.uid = user.uid
|
注意:此處只是為了示範用 INNER JOIN 替換關聯子查詢的範例,並非表名這種處理是最優處理