oracle中where中使用函数,Oracle 尽量避免在 SQL语句的WHERE子句中使用函数
-- Start
在 WHERE 子句中應(yīng)該盡量避免在列上使用函數(shù),因?yàn)檫@樣做會使該列上的索引失效,影響SQL 語句的性能。即使該列上沒有索引,也應(yīng)該避免在列上使用函數(shù)。考慮下面的情況:
CREATE TABLE EMPLOYEE
(
NAME VARCHAR2(20) NOT NULL,---姓名
REGISTERDATE TIMESTAMP---注冊時(shí)間
);
現(xiàn)在要求你把2009-9-24 注冊的用戶都查出來,怎么辦?可能有人會這么寫:
SELECT * FROM EMPLOYEE WHERE TO_DATE(REGISTERDATE) = DATE '2009-09-24';
上述語句完全正確,但是假如 REGISTERDATE 列上有索引,那么會使索引失效,即使沒有索引,也不應(yīng)該這么做。那么到底如何處理呢?答案是將它轉(zhuǎn)化為范圍掃描,如下:
SELECT * FROM EMPLOYEE WHERE REGISTERDATE >= TIMESTAMP '2009-9-24 00:00:00.0' AND REGISTERDATE < TIMESTAMP '2009-9-25 00:00:00.0';
--?更多參見:Oracle SQL 精萃
--?聲明:轉(zhuǎn)載請注明出處
-- Last edited on 2015-06-19
-- Created by?ShangBo on?2015-06-19
-- End
總結(jié)
以上是生活随笔為你收集整理的oracle中where中使用函数,Oracle 尽量避免在 SQL语句的WHERE子句中使用函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 图标题上移_Python-
- 下一篇: 红黑树与平衡二叉树_百图详解红黑树,想不