Вы можете попробовать тип данных INTERVAL DAY TO SECOND, но он не сохранит вам никакого дискового пространства ... он очень подходит для этой цели.
create table t1 (time_of_day interval day (0) to second(0));
insert into t1 values (TO_DSINTERVAL('0 23:59:59'));
select date '2009-05-13'+time_of_day
from t1;
11 байтов.