關(guān)聯(lián)子查詢是指一個(gè)包含對(duì)表的引用的子查詢,該表也顯示在外部查詢中,通俗一點(diǎn)來講,就是子查詢引用到了主查詢的數(shù)據(jù)數(shù)據(jù).
以一個(gè)實(shí)際的例子來理解關(guān)聯(lián)子查詢:
left join:左連接,返回左表中所有的記錄以及右表中連接字段相等的記錄.
right join:右連接,返回右表中所有的記錄以及左表中連接字段相等的記錄.
inner join:內(nèi)連接,又叫等值連接,只返回兩個(gè)表中連接字段相等的行.
full join:外連接,返回兩個(gè)表中的行:left join + right join.
cross join:結(jié)果是笛卡爾積,就是第一個(gè)表的行數(shù)乘以第二個(gè)表的行數(shù).
代碼如下:
- 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 --Vevb.com
- --左:
- 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
- --內(nèi)
- 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
關(guān)聯(lián)子查詢效率:
很明顯,一般情況下關(guān)聯(lián)子查詢的效率是比較低下的,實(shí)際上本例中的關(guān)聯(lián)子查詢例子也僅是為了演示關(guān)聯(lián)子查詢的原理及用法,如果可以的話,關(guān)聯(lián)子查詢盡量使用 JOIN 或其他查詢來代替,如本例中,使用 INNER JOIN 來替換的 SQL 為.SELECT article.* FROM article INNER JOIN user ON article.uid = user.uid
注意:此處只是為了演示用 INNER JOIN 替換關(guān)聯(lián)子查詢的樣例,并非表名這種處理是最優(yōu)處理.
新聞熱點(diǎn)
疑難解答
圖片精選