新聞中心
在向大家詳細(xì)介紹Oracle Where子句之前,首先讓大家了解下ORDER BY子句,然后全面介紹用Oracle Where子句替代ORDER BY:
◆ORDER BY 子句只在兩種嚴(yán)格的條件下使用索引。
◆ORDER BY中任何的列必須包含在相同的索引中并保持在索引中的排列順序。
◆ORDER BY中任何的列必須定義為非空。

10年的高昌網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。全網(wǎng)整合營(yíng)銷(xiāo)推廣的優(yōu)勢(shì)是能夠根據(jù)用戶(hù)設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整高昌建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)建站從事“高昌網(wǎng)站設(shè)計(jì)”,“高昌網(wǎng)站推廣”以來(lái),每個(gè)客戶(hù)項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
Oracle Where子句使用的索引和ORDER BY子句中所使用的索引不能并列。例如: 表DEPT包含以下列:
- DEPT_CODE PK NOT NULL
- DEPT_DESC NOT NULL
- DEPT_TYPE NULL
避免改變索引列的類(lèi)型:
當(dāng)比較不同數(shù)據(jù)類(lèi)型的數(shù)據(jù)時(shí), Oracle自動(dòng)對(duì)列進(jìn)行簡(jiǎn)單的類(lèi)型轉(zhuǎn)換。 假設(shè) EMPNO是個(gè)數(shù)值類(lèi)型的索引列:SELECT … FROM EMP WHERE EMPNO = ‘123'。 實(shí)際上,經(jīng)過(guò)Oracle類(lèi)型轉(zhuǎn)換, 語(yǔ)句轉(zhuǎn)化為: SELECT … FROM EMP WHERE EMPNO = TO_NUMBER(‘123') 。
幸運(yùn)的是,類(lèi)型轉(zhuǎn)換沒(méi)有發(fā)生在索引列上,索引的用途沒(méi)有被改變。現(xiàn)在,假設(shè)EMP_TYPE是個(gè)字符類(lèi)型的索引列:SELECT … FROM EMP WHERE EMP_TYPE = 123 。
這個(gè)語(yǔ)句被Oracle轉(zhuǎn)換為: SELECT … FROM EMP WHERETO_NUMBER(EMP_TYPE)=123。因?yàn)閮?nèi)部發(fā)生的類(lèi)型轉(zhuǎn)換,這個(gè)索引將不會(huì)被用到! 為了避免Oracle對(duì)您的SQL進(jìn)行隱式的類(lèi)型轉(zhuǎn)換,***把類(lèi)型轉(zhuǎn)換用顯式表現(xiàn)出來(lái)。注意當(dāng)字符和數(shù)值比較時(shí),Oracle會(huì)優(yōu)先轉(zhuǎn)換數(shù)值類(lèi)型到字符類(lèi)型。
需要當(dāng)心的Oracle Where子句:
某些SELECT 語(yǔ)句中的Oracle Where子句不使用索引。這里有一些例子:
(1)‘!=' 將不使用索引。記住, 索引只能告訴您什么存在于表中, 而不能告訴您什么不存在于表中。
(2)‘||'是字符連接函數(shù)。就象其他函數(shù)那樣, 停用了索引。
(3)‘ '是數(shù)學(xué)函數(shù)。就象其他數(shù)學(xué)函數(shù)那樣, 停用了索引。
(4)相同的索引列不能互相比較,這將會(huì)啟用全表掃描。
a. 假如檢索數(shù)據(jù)量超過(guò)30%的表中記錄數(shù),使用索引將沒(méi)有顯著的效率提高。
b. 在特定情況下,使用索引也許會(huì)比全表掃描慢,但這是同一個(gè)數(shù)量級(jí)上的區(qū)別。而通常情況下,使用索引比全表掃描要塊幾倍乃至幾千倍!
避免使用耗費(fèi)資源的操作:
帶有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL語(yǔ)句會(huì)啟動(dòng)SQL引擎執(zhí)行耗費(fèi)資源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要執(zhí)行兩次排序。通常,帶有 UNION, MINUS , INTERSECT的SQL語(yǔ)句都能夠用其他方式重寫(xiě)。假如您的數(shù)據(jù)庫(kù)的SORT_AREA_SIZE調(diào)配得好。使用UNION , MINUS, INTERSECT也是能夠考慮的, 畢竟他們的可讀性很強(qiáng)。
文章題目:OracleWhere子句研究結(jié)論
鏈接地址:http://m.fisionsoft.com.cn/article/djddhic.html


咨詢(xún)
建站咨詢(xún)
