本文主要給大家介紹了關(guān)于oracle使用強制索引的方法與注意事項,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。希望能幫助到大家。
oracle使用強制索引
在一些場景下,可能ORACLE不會自動走索引,這時候,如果對業(yè)務清晰,可以嘗試使用強制索引,測試查詢語句的性能。
以EMP表為例:
先在EMP表中建立唯一索引,如圖。
普通搜索:
SELECT?*?FROM?EMP?T
查看執(zhí)行計劃:
可以看到,是走的全表掃描。
使用強制索引,在SELECT 后面加上/*…….*/ 中間加上索引的屬性,代碼如下:
SELECT?/*+index(t?pk_emp)*/*?FROM?EMP?T? --強制索引,/*.....*/第一個星星后不能有空格,里邊內(nèi)容結(jié)構(gòu)為:加號index(表名?空格?索引名)。 --如果表用了別名,注釋里的表也要使用別名。
?
可以看到,這是走的是索引PK_EMP。
Oracle使用強制索引注意事項
最近對Oracle的SQL索引生效條件進行了驗證,發(fā)現(xiàn)如下規(guī)律,記錄如下:
1、索引生效與記錄的條數(shù)相關(guān)
????? a、2016-01-01~2016-11-30 數(shù)據(jù)量402518,索引生效
????? b、2016-01-01~2016-12-30 數(shù)據(jù)量444844,索引不生效
SELECT? ?*? FROM? ?T_MAINS? WHERE? ?date?>?TO_DATE?(--備注今天是2017-01-23? ??'2016-01-01',? ??'yyyy-mm-dd?hh24:mi:ss'? ?)? AND?date?<p></p><p><strong>2、T_MAINS已根據(jù)某個時間類型的字段進行分區(qū),查詢條件中如果能夠精準定位到某個分區(qū),可以提高SQL的執(zhí)行效率</strong></p><p>相關(guān)推薦:</p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql與oracle數(shù)據(jù)庫停止與啟動的批處理文件</a></p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql與oracle數(shù)據(jù)庫停止與啟動的批處理文件</a></p><p><a href="http://www.php.cn/mysql-tutorials-377830.html" target="_self">mysql與oracle數(shù)據(jù)庫停止與啟動的批處理文件</a></p>
? 版權(quán)聲明
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載。
THE END