sql語句優化:用join取代not in
阿新 • • 發佈:2019-01-10
寫了好幾個頁面,速度都上不去,瓶頸在於SQL查詢。太多的表,太多的not in,總是從一大推表和資料中篩選出一點資料。看了很多關於SQL優化的文章,都強烈要求不要太多使用not in查詢,最好用表連線來取代它。如:
select ID,name from Table_A where ID not in (select ID from Table_B)
這句是最經典的not in查詢了。改為表連線程式碼如下:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID and Table_B.ID is null
或者:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID where Table_B.ID is null
select ID,name from Table_A where ID not in (select ID from Table_B)
這句是最經典的not in查詢了。改為表連線程式碼如下:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID and Table_B.ID is null
或者:
select Table_A.ID,Table_A.name from Table_A left join Table_B on Table_A.ID=Table_B.ID where Table_B.ID is null
經試用,效果立竿見影。
可以這樣理解:
left join 會先把A表 全查出來
再把 B表id與A表相等的,不相等的(為null)都查出來
再從結果中 搜出來 B表 id 為空(null)的。
之前的每一條都要 遍歷一遍 id. 所以效率低下