国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > 文庫 > 正文

sql中l(wèi)eft join的效率分析與提高效率方法

2020-10-29 21:46:59
字體:
供稿:網(wǎng)友

網(wǎng)站隨著數(shù)據(jù)量與訪問量越來越大,訪問的速度變的越來越慢,于是開始想辦法解決優(yōu)化速度慢的原因

下面是對程序中一條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)。或者給關(guān)聯(lián)的字段加索引

網(wǎng)上還看到有人說,將left join右邊的表數(shù)據(jù)補(bǔ)齊,然后將left join 替換為 inner join。我試過,速度確實(shí)快很多,但考慮到數(shù)據(jù)量的問題,未測試此方法。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鹰潭市| 泾阳县| 内黄县| 宁陕县| 阿坝县| 怀集县| 深泽县| 竹北市| 华亭县| 克拉玛依市| 叙永县| 神农架林区| 合川市| 云梦县| 普洱| 永泰县| 浪卡子县| 凤台县| 西昌市| 玉门市| 黄龙县| 屏边| 商丘市| 贡觉县| 德令哈市| 柳林县| 灯塔市| 佛教| 太白县| 武隆县| 达拉特旗| 新源县| 新昌县| 武宁县| 阜城县| 邓州市| 南投县| 潼关县| 中方县| 永州市| 揭东县|