您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“sql中l(wèi)eft join的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“sql中l(wèi)eft join的示例分析”這篇文章吧。
網(wǎng)站隨著數(shù)據(jù)量與訪問量越來越大,訪問的速度變的越來越慢,于是開始想辦法解決優(yōu)化速度慢的原因
下面是對(duì)程序中一條sql的分析過程,當(dāng)然程序的執(zhí)行效率不單單是sql語句的問題,還有可能是服務(wù)器配置,網(wǎng)速,程序語言等各方法的問題,今天我們先來分析一下sql語句中l(wèi)eft join的效率問題
sql語句中包含以下信息:
1、sql包含數(shù)據(jù)處理函數(shù),比如nvl函數(shù),case when函數(shù)等
2、sql中包含inner join,left join等關(guān)聯(lián)關(guān)系
3、sql中有排序和分頁
下面是分析過程
1、首先把排序去掉,速度確實(shí)很快,但沒辦法,排序是必須的,這樣做只是為了證明排序確實(shí)是很耗資源
2、將nvl,case when等函數(shù)去掉,結(jié)果速度幾乎沒有任何改變
3、將inner join的表去除,速度稍微快了幾十毫秒
4、將left join的表去掉,速度從原來的4秒提高到1秒內(nèi)。
綜合所得,left join才是速度慢的元兇,于是將left join關(guān)聯(lián)關(guān)系字段都加為索引,在測試,發(fā)現(xiàn)速度基本能保持在1秒左右。問題解決。
結(jié)論:left join是相當(dāng)耗資源的操作,如果關(guān)聯(lián)的字段沒有索引的話,速度是很慢的,所以如果有l(wèi)eft join的話,最好用索引字段取關(guān)聯(lián)?;蛘?strong>給關(guān)聯(lián)的字段加索引
網(wǎng)上還看到有人說,將left join右邊的表數(shù)據(jù)補(bǔ)齊,然后將left join 替換為 inner join。我試過,速度確實(shí)快很多,但考慮到數(shù)據(jù)量的問題,未測試此方法。
以上是“sql中l(wèi)eft join的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。