Oracle使用強(qiáng)制索引的方法與注意事項(xiàng)
Oracle使用強(qiáng)制索引
在一些場景下,可能ORACLE不會(huì)自動(dòng)走索引,這時(shí)候,如果對業(yè)務(wù)清晰,可以嘗試使用強(qiáng)制索引,測試查詢語句的性能。
以EMP表為例:
先在EMP表中建立唯一索引,如圖。
普通搜索:
SELECT * FROM EMP T
查看執(zhí)行計(jì)劃:
可以看到,是走的全表掃描。
使用強(qiáng)制索引,在SELECT 后面加上/*.......*/ 中間加上索引的屬性,代碼如下:
SELECT /*+index(t pk_emp)*/* FROM EMP T --強(qiáng)制索引,/*.....*/第一個(gè)星星后不能有空格,里邊內(nèi)容結(jié)構(gòu)為:加號(hào)index(表名 空格 索引名)。 --如果表用了別名,注釋里的表也要使用別名。
可以看到,這是走的是索引PK_EMP。
Oracle使用強(qiáng)制索引注意事項(xiàng)
最近對Oracle的SQL索引生效條件進(jìn)行了驗(yàn)證,發(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 < TO_DATE ( '2016-11-30', 'yyyy-mm-dd hh24:mi:ss' );
2、T_MAINS已根據(jù)某個(gè)時(shí)間類型的字段進(jìn)行分區(qū),查詢條件中如果能夠精準(zhǔn)定位到某個(gè)分區(qū),可以提高SQL的執(zhí)行效率
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Oracle數(shù)據(jù)庫如何獲取多條結(jié)果集中的第一條或某一條
Oracle從多條符合條件的記錄中選擇一條這個(gè)需求相信大家應(yīng)該都遇到過,這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫如何獲取多條結(jié)果集中的第一條或某一條的相關(guān)資料,需要的朋友可以參考下2023-03-03Oracle與SQL Server在企業(yè)應(yīng)用的比較
Oracle與SQL Server在企業(yè)應(yīng)用的比較...2007-03-03oracle更新xml節(jié)點(diǎn)問題的一些細(xì)節(jié)
本節(jié)主要介紹了oracle更新xml節(jié)點(diǎn)問題的一些細(xì)節(jié),需要的朋友可以參考下2014-08-08Oracle中實(shí)現(xiàn)一次插入多條數(shù)據(jù)詳細(xì)代碼舉例
公司的項(xiàng)目,有個(gè)功能每次使用需要向數(shù)據(jù)庫插入很多數(shù)據(jù),這里給大家總結(jié)下,這篇文章主要給大家介紹了Oracle中實(shí)現(xiàn)一次插入多條數(shù)據(jù)的相關(guān)資料,文中通過圖文及代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06解決PL/SQL修改Oracle存儲(chǔ)過程編譯就卡死的問題
這篇文章主要介紹了PL/SQL修改Oracle存儲(chǔ)過程編譯就卡死,本文給大家分享問題原因及解決方法,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01