Найти запись в БД с диапазоном OffsetDateTime в Java - PullRequest
0 голосов
/ 29 октября 2018

У меня есть столбец даты в моей базе данных postgres, и я хочу иметь возможность найти запись с заданным диапазоном дат.

Например, в моей базе данных есть запись со столбцом 2018-10-29 09:05:30.100 updatetime. Я хочу найти эту запись с OffsetDateTime + - 5 секунд.

Как я могу исправить это в своем Java-коде, чтобы сказать db, чтобы получить запись между 2018-10-29 09:05:25.100 и 2018-10-29 09:05:35.100? (В этом диапазоне может быть только 1 запись, поэтому не беспокойтесь о результате.)

Ответы [ 2 ]

0 голосов
/ 29 октября 2018

При использовании класса 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 .

0 голосов
/ 29 октября 2018

это должно работать

String sqlQuery = "select * from table_name where updatetime <= '" 
           + yourDatetime.toString() +
           "'::timestamp with time zone + interval '5 second' and updatetime >= '" + 
           + yourDatetime.toString() + "'::timestamp with time zone - interval '5 second'";

но вы должны отформатировать yourDatetime переменную как

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");

Примечание: Вы можете отформовать sqlQuery соответственно, чтобы подготовить свое заявление.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...