Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Wie erhalte ich das aktuelle Jahr mit SQL on Oracle?

Verwendung von to_char:

select to_char(sysdate, 'YYYY') from dual;

In Ihrem Beispiel können Sie so etwas verwenden:

BETWEEN trunc(sysdate, 'YEAR') 
    AND add_months(trunc(sysdate, 'YEAR'), 12)-1/24/60/60;

Die Vergleichswerte sind genau das, was Sie anfordern:

select trunc(sysdate, 'YEAR') begin_year
     , add_months(trunc(sysdate, 'YEAR'), 12)-1/24/60/60 last_second_year
from dual;

BEGIN_YEAR  LAST_SECOND_YEAR
----------- ----------------
01/01/2009  31/12/2009