При использовании класса OffsetDateTime
вас должны интересовать моменты, фактические точки на временной шкале. Если это так, столбец базы данных должен иметь тип данных TIMESTAMP WITH TIME ZONE
(, а не WITHOUT
).
Но, как ни странно, в данных вашего примера отсутствует offset-from-UTC , количество часов, минут и секунд. Вы должны указать смещение или часовой пояс (ZoneId
& ZonedDateTime
) для определения момента.
Я откорректирую вашу входную строку, назначив произвольное смещение.
OffsetDateTime odt = OffsetDateTime.parse( "2018-10-29T09:05:30.100+02:00" );
Настройте на ± 5 секунд.
Duration d = Duration.ofSeconds( 5 ) ;
OffsetDateTime start = odt.minus( d ) ;
OffsetDateTime stop = odt.plus( d ) ;
Начиная с JDBC 4.2, мы можем напрямую обмениваться java.time объектами с базой данных.
Здесь мы используем общий подход Half-Open для определения промежутка времени. Начало включительно , а окончание эксклюзив . Обратите внимание, что мы не используем команду SQL BETWEEN
.
String sql = "SELECT * FROM event WHERE when >= ? AND when < ? ;" ;
PreparedStatement pstmt = con.prepareStatement( sql ) ;
pstmt.setObject( 1 , start ) ;
pstmt.setObject( 2 , stop ) ;
Получение значений.
OffsetDateTime odt = myResultSet.getObject( … , OffsetDateTime.class ) ;
О java.time
Фреймворк java.time встроен в Java 8 и более поздние версии. Эти классы вытесняют проблемные старые унаследованные классы даты и времени, такие как java.util.Date
, Calendar
, & SimpleDateFormat
.
Проект Joda-Time , теперь в режиме обслуживания , рекомендует перейти на классы java.time .
Чтобы узнать больше, см. Oracle Tutorial . И поиск переполнения стека для многих примеров и объяснений. Спецификация JSR 310 .
Вы можете обмениваться java.time объектами непосредственно с вашей базой данных. Используйте драйвер JDBC , совместимый с JDBC 4.2 или более поздней версии. Нет необходимости в строках, нет необходимости в java.sql.*
классах.
Где взять классы java.time?
Проект ThreeTen-Extra расширяет java.time дополнительными классами. Этот проект является полигоном для возможных будущих дополнений к java.time. Здесь вы можете найти несколько полезных классов, таких как Interval
, YearWeek
, YearQuarter
и more .