Oracle復(fù)合索引與空值的索引使用問(wèn)題小結(jié)
昨天在QQ群里討論一個(gè)SQL優(yōu)化的問(wèn)題,語(yǔ)句大致如下:
select A,min(B) from table group by A;--A,B都沒(méi)有not null約束,A列無(wú)空值,B列有空值。--存在復(fù)合索引IX_TEST(A,B)
于是手動(dòng)測(cè)試,環(huán)境采用Oracle自帶的scott用戶下的emp表。
1.首先查看如下語(yǔ)句的執(zhí)行計(jì)劃(此時(shí)表只有主鍵索引):

2.添加IX_TEST(deptno,comm)后查看執(zhí)行計(jì)劃:


發(fā)現(xiàn)依然是全表掃描。
3.為deptno列添加非空約束后再次查看執(zhí)行計(jì)劃:


4.總結(jié):
Btree索引是不存儲(chǔ)空值的,這個(gè)是所有使用Btree索引的數(shù)據(jù)庫(kù)的共同點(diǎn)。
在本例中我們創(chuàng)建了deptno,comm的符合索引。如果deptno沒(méi)有非空約束,那么說(shuō)明有的record不會(huì)出現(xiàn)在索引中,此時(shí)想要找到min(comm)就必須回表才能確定deptno為null的行是否有comm的值。此時(shí)優(yōu)化器認(rèn)為全表掃描比掃描索引再回表更為合理,因此選擇全表掃描。
當(dāng)我們添加了非空約束后,deptno不可能為空,因此索引的key值數(shù)等于表總行數(shù),另一列comm即便為空也不影響min()取值,只需要掃描索引即可得到所需結(jié)果,此時(shí)優(yōu)化器選擇索引掃描。
而在Mysql中無(wú)論復(fù)合索引首列是否存在非空約束,都會(huì)使用索引,deptno為null的會(huì)全部分在一組取min(comm),可能是Mysql的BTREE索引與Oracle的有所不同,使得首列為空都可以無(wú)需回表。
最后:Oracle的列能添加非空約束的一定要添加。
總結(jié)
以上所述是小編給大家介紹的Oracle復(fù)合索引與空值的索引使用問(wèn)題小結(jié),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle12c的數(shù)據(jù)庫(kù)向11g導(dǎo)進(jìn)的方法
這篇文章主要介紹了 Oracle12c的數(shù)據(jù)庫(kù)向11g導(dǎo)進(jìn)的方法的相關(guān)資料,需要的朋友可以參考下2016-03-03
oracle 數(shù)據(jù)庫(kù)閃回相關(guān)語(yǔ)句介紹
本文將詳細(xì)介紹oracle 數(shù)據(jù)庫(kù)閃回相關(guān)語(yǔ)句,需要了解跟多的朋友可以參考下2012-11-11
ORACLE創(chuàng)建DBlink的過(guò)程及使用方法
這篇文章主要介紹了ORACLE DBlink的創(chuàng)建和使用,本文通過(guò)實(shí)例代碼給大家給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06
Linux 自動(dòng)備份oracle數(shù)據(jù)庫(kù)詳解
這篇文章主要介紹了Linux 自動(dòng)備份oracle數(shù)據(jù)庫(kù)詳解方法的相關(guān)資料,數(shù)據(jù)庫(kù)的備份的重要性,不言而喻,希望能幫到大家,需要的朋友可以參考下2016-10-10
VMware中l(wèi)inux環(huán)境下oracle安裝圖文教程(二)ORACLE 10.2.05版本的升級(jí)補(bǔ)丁安裝
這篇文章是VMware中l(wèi)inux環(huán)境下oracle安裝圖文教程系列的第二篇,主要介紹了ORACLE 10.2.05版本的升級(jí)補(bǔ)丁安裝,需要的朋友可以參考下2014-08-08
使用Oracle通過(guò)gateway連接MSSQL的詳細(xì)流程
oracle Gateway是Oracle公司提供的一種訪問(wèn)非Oracle數(shù)據(jù)源的方法,它可以將非Oracle數(shù)據(jù)源(如SQLserver、mysql等)的數(shù)據(jù)看作是oracle數(shù)據(jù)庫(kù)中的表,從而可以使用SQL和PLSQL等Oracle語(yǔ)言來(lái)訪問(wèn)這些數(shù)據(jù),本文介紹了使用Oracle通過(guò)gateway連接MSSQL的詳細(xì)流程2024-12-12
詳解Oracle如何將txt文件中的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)
這篇文章主要介紹了Oracle如何將txt文件中的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù),文中通過(guò)代碼示例和圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03

