sql中left join的效率分析與提高效率方法,leftjoin

來源:互聯網
上載者:User

sql中left join的效率分析與提高效率方法,leftjoin

網站隨著資料量與訪問量越來越大,訪問的速度變的越來越慢,於是開始想辦法解決最佳化速度慢的原因

下面是對程式中一條sql的分析過程,當然程式的執行效率不單單是sql語句的問題,還有可能是伺服器配置,網速,程式語言等各方法的問題,今天我們先來分析一下sql語句中left join的效率問題

sql語句中包含以下資訊:

1、sql包含資料處理函數,比如nvl函數,case when函數等

2、sql中包含inner join,left join等關聯關係

3、sql中有排序和分頁

下面是分析過程

1、首先把排序去掉,速度確實很快,但沒辦法,排序是必須的,這樣做只是為了證明排序確實是很耗資源

2、將nvl,case when等函數去掉,結果速度幾乎沒有任何改變

3、將inner join的表去除,速度稍微快了幾十毫秒

4、將left join的表去掉,速度從原來的4秒提高到1秒內。

綜合所得,left join才是速度慢的元兇,於是將left join關聯關係欄位都加為索引,在測試,發現速度基本能保持在1秒左右。問題解決。

結論:left join是相當耗資源的操作,如果關聯的欄位沒有索引的話,速度是很慢的,所以如果有left join的話,最好用索引欄位取關聯。或者給關聯的欄位加索引

網上還看到有人說,將left join右邊的表資料補齊,然後將left join 替換為 inner join。我試過,速度確實快很多,但考慮到資料量的問題,未測試此方法。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.