[原文連接] http://www.cnblogs.com/aaapeng/archive/2010/01/20/1652151.html#commentformhtml
聯合查詢效率較高.如下例子來講明聯合查詢的好處post
t1表結構(用戶名,密碼) userid int username varchar(20) password varchar(20)測試
1 jack jackpwdorm
2 owen owenpwdhtm
t3表結構(用戶積分,等級) userid int jf int dj intblog
1 20 3form
3 50 6效率
第一:內聯(inner join)select
若是想把用戶信息,積分,等級都列出來.那麼通常會這樣寫密碼
select * from t1 ,t3 where t1.userid = t3.userid 其實這樣的結果等同於select * from t1 inner join t3 on t1.userid=t3.userid
就是把兩個表中都存在userid的行拼成一行.這是內聯.但後者的效率會比前者高不少.建議用後者的寫法.
運行結果:userid username password userid jf dj
1 jack jacjpwd 1 20 3
第二:左聯(left outer join)顯示左表中的全部行
select * from t1 left outer join t3 on t1.userid=t3.userid
運行結果:userid username password userid jf dj
1 jack jackpwd 1 20 3
2 owen owenpwd NULL NULL NULL
第三:右聯(right outer join)顯示右表中的全部行
select * from t1 right outer join t3 on t1.userid=t3.userid
運行結果:userid username password userid jf dj
1 jack jackpwd 1 20 3
Null Null Null 3 50 6
第四:全聯(full outer join)顯示兩邊表中全部行
select * from t1 full outer join t3 on t1.userid=t3.userid
運行結果:userid username password userid jf dj
1 jack jackpwd 1 20 3
2 owen owenpwd NULL NULL NULL
Null Null Null 3 50 6
總結,關於聯合查詢,本人已測試過.效率的確比較高,4種聯合方式若是能夠靈活使用,基本上覆雜的語句結構也會簡單起來.這4種方式是:
Inner join left outer join right outer join full outer join