濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Oracle提高SQL執(zhí)行效率的3種方法

Oracle提高SQL執(zhí)行效率的3種方法

熱門標(biāo)簽:百度地圖標(biāo)注素材 word地圖標(biāo)注方向 阿爾巴尼亞地圖標(biāo)注app 人工智能地圖標(biāo)注自己能做嗎 征服眼公司地圖標(biāo)注 征服者火車站地圖標(biāo)注 外呼線路外顯本地號(hào)碼 美圖秀秀地圖標(biāo)注 開封智能外呼系統(tǒng)廠家
Oracle提供了多種方法用于減少花在剖析Oracle SQL表達(dá)式上的時(shí)間,在執(zhí)行帶有大量執(zhí)行計(jì)劃的復(fù)雜查詢時(shí)剖析過(guò)程會(huì)拖累系統(tǒng)的性能。現(xiàn)在我們來(lái)簡(jiǎn)要地看看這些方法中的幾種。

1、使用ordered提示

Oracle必須花費(fèi)大量的時(shí)間來(lái)剖析多表格的合并,用以確定表格合并的最佳順序。如果SQL表達(dá)式涉及七個(gè)乃至更多的表格合并,那么有時(shí)就會(huì)需要超過(guò)30分鐘的時(shí)間來(lái)剖析,因?yàn)镺racle必須評(píng)估表格合并所有可能的順序。八個(gè)表格就會(huì)有40,000多種順序。Ordered這個(gè)提示(hint)和其他的提示一起使用能夠產(chǎn)生合適的合并順序。

Ordered這個(gè)提示會(huì)要求列在SQL表達(dá)式FROM字句里的表格按照指定的順序進(jìn)行合并,F(xiàn)ROM字句里的第一個(gè)表格會(huì)指定驅(qū)動(dòng)表格(driving table)。驅(qū)動(dòng)表格應(yīng)該是返回最小行數(shù)的表格。使用ordered提示會(huì)跳過(guò)非常耗時(shí)和耗資源的剖析操作,并加快Oracle SQL的執(zhí)行。

Listing A如下:

以下是引用片段:

Listing A

select /*+ ordered use_nl(bonus)

parallel(e, 4) */ e.ename, hiredate, b.comm from emp e, bonus b

where e.ename = b.ename ;

Listing A里是一個(gè)復(fù)雜查詢的例子,這個(gè)查詢被強(qiáng)制進(jìn)行一個(gè)嵌套循環(huán),從而與對(duì)emp表格進(jìn)行的并行查詢合并。要注意,我已經(jīng)使用ordered提示來(lái)引導(dǎo)Oracle去按照WHERE子句所列出的順序來(lái)評(píng)估表格。

2、使用theordered_predicates

ordered_predicates提示在查詢的WHERE子句里指定的,并被用來(lái)指定布爾判斷(Boolean predicate)被評(píng)估的順序。在沒(méi)有ordered_predicates的情況下,Oracle會(huì)使用下面這些步驟來(lái)評(píng)估SQL判斷的順序:

子查詢的評(píng)估先于外層WHERE子句里的Boolean條件。

所有沒(méi)有內(nèi)置函數(shù)或者子查詢的布爾條件都按照其在WHERE子句里相反的順序進(jìn)行評(píng)估,即最后一條判斷最先被評(píng)估。

每個(gè)判斷都帶有內(nèi)置函數(shù)的布爾判斷都依據(jù)其預(yù)計(jì)的評(píng)估值按遞增排列。

你可以使用ordered_predicates提示來(lái)強(qiáng)制取代這些缺省的評(píng)估規(guī)則,那么你WHERE子句里的項(xiàng)目就會(huì)按照其在查詢里出現(xiàn)的順序被評(píng)估。在查詢的WHERE子句里使用了PL/SQL函數(shù)的情況下,通常會(huì)使用ordered_predicates提示。如果你知道限制最多的判斷并且希望Oracle最先評(píng)估這些判斷的時(shí)候,在這種情況下,它也是非常有用的。用法提示:你不能使用ordered_predicates提示來(lái)保存對(duì)索引鍵進(jìn)行判斷評(píng)估的順序。

3、限制表格合并評(píng)估的數(shù)量

提高SQL剖析性能的最后一種方法是強(qiáng)制取代Oracle的一個(gè)參數(shù),這個(gè)參數(shù)控制著在評(píng)估一個(gè)查詢的時(shí)候,基于消耗的優(yōu)化器所評(píng)估的可能合并數(shù)量。

optimizer_search_limit這個(gè)參數(shù)會(huì)指定表格合并組合的最大數(shù)量,后者將會(huì)在Oracle試圖確定合并多表格最佳方式的時(shí)候被評(píng)估。這個(gè)參數(shù)有助于防止優(yōu)化器花更多的時(shí)間來(lái)評(píng)估可能的合并順序,而不是把時(shí)間花在尋找最佳合并順序上。optimizer_search_limit還控制著用于調(diào)用star join提示的闕值,當(dāng)查詢里的表格數(shù)量低于optimizer_search_limit(其缺省的值是5)的時(shí)候,star提示就會(huì)被光顧。
您可能感興趣的文章:
  • sql格式化工具集合
  • SQL查詢效率注意事項(xiàng)小結(jié)
  • mysql格式化小數(shù)保留小數(shù)點(diǎn)后兩位(小數(shù)點(diǎn)格式化)
  • SQL Server中的SQL語(yǔ)句優(yōu)化與效率問(wèn)題
  • C++操作MySQL大量數(shù)據(jù)插入效率低下的解決方法
  • C#適用于like語(yǔ)句的SQL格式化函數(shù)
  • 提高M(jìn)ySQL中InnoDB表BLOB列的存儲(chǔ)效率的教程
  • 通過(guò)格式良好的SQL提高效率和準(zhǔn)確性

標(biāo)簽:泰安 海北 酒泉 宜春 淮南 孝感 六安 葫蘆島

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle提高SQL執(zhí)行效率的3種方法》,本文關(guān)鍵詞  Oracle,提高,SQL,執(zhí)行,效率,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Oracle提高SQL執(zhí)行效率的3種方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Oracle提高SQL執(zhí)行效率的3種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    大竹县| 新龙县| 思茅市| 博野县| 富蕴县| 禄劝| 莒南县| 万年县| 微博| 育儿| 乐业县| 汶上县| 西宁市| 曲靖市| 黔西| 海门市| 包头市| 蓝田县| 固镇县| 三台县| 沭阳县| 合阳县| 乌兰县| 广灵县| 兴安县| 沙河市| 安泽县| 志丹县| 开阳县| 谷城县| 漠河县| 天长市| 景洪市| 古丈县| 临城县| 南雄市| 科尔| 罗源县| 北碚区| 鸡东县| 漳浦县|