I have a table with a date column. I used JDBC to save a java.util.Date object into the table.
When I run following query I get date aswell as a time value:
select To_CHAR(departure_date,'DD-MM-YYYY HH:MI') from service
This tells me that date is column is also storing time.
This is unexpected. Shouldn't date type discard time value like an integer type discards fractional digits?
Best Answer
Oracle's
DATE
datatype behaves as both an ANSIDATE
andTIME
datatype. This was a design decision that only Oracle knows the reasoning for.I'll add that Oracle isn't the only RDBMS that doesn't follow ANSI SQL standards in this way.
Obviously, you can remove the time portion with
TO_CHAR(departure_date,'DD-MM-YYYY')
.