1. 程式人生 > >Oracle 儘量避免在 SQL語句的WHERE子句中使用函式

Oracle 儘量避免在 SQL語句的WHERE子句中使用函式

-- Start

在 WHERE 子句中應該儘量避免在列上使用函式,因為這樣做會使該列上的索引失效,影響SQL 語句的效能。即使該列上沒有索引,也應該避免在列上使用函式。考慮下面的情況:

CREATE TABLE EMPLOYEE
(
NAME         VARCHAR2(20) NOT NULL,---姓名
REGISTERDATE TIMESTAMP---註冊時間
);

現在要求你把2009-9-24 註冊的使用者都查出來,怎麼辦?可能有人會這麼寫:
SELECT * FROM EMPLOYEE WHERE TO_DATE(REGISTERDATE) = DATE '2009-09-24';

上述語句完全正確,但是假如 REGISTERDATE 列上有索引,那麼會使索引失效,即使沒有索引,也不應該這麼做。那麼到底如何處理呢?答案是將它轉化為範圍掃描,如下:
SELECT * FROM EMPLOYEE WHERE REGISTERDATE >= TIMESTAMP '2009-9-24 00:00:00.0' AND REGISTERDATE < TIMESTAMP '2009-9-25 00:00:00.0';

-- 宣告:轉載請註明出處

-- Last edited on 2015-06-19

-- Created by ShangBo on 2015-06-19

-- End