Oracle中一個日期尋找的誤區

來源:互聯網
上載者:User

經常要在資料中檢索近一個月來發生的資料,所以採用如下語句select * from eventtable where eventdate>sysdate-30,當資料量小的時候還看不出來,資料量大一些就會發現上面的語句很慢,但eventdate日期型欄位)上也是有索引的,可為什麼會慢呢? 原來是oracle在進行尋找的時候不斷地去取sysdate這個不斷變化的值,而不是我們想象中的一次產生一個條件陳述式然後進行尋找。為了加快速度,我們可以先把當天的日期取出來,然後轉成字串後再用如下語句查,select * from eventtable where eventdate > to_date(2001-12-1,yyyy-mm-dd)。速度竟然差了幾十倍。


相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.