ТЛ; др
… могу ли я создать java.sql.timestamp без часового пояса…
Нет, вы не можете. Неправильный класс. Вместо этого используйте java.time.LocalDateTime
.
Подробнее
A java.sql.Timestamp
- неправильный класс для использования. Он представляет собой момент в UTC с разрешением наносекунд.
Если вам нужна дата с указанием времени суток независимо от часового пояса или смещения от UTC (например, , а не мгновение), используйте другой класс, который подходит для этой цели.
Кстати ... java.sql.Timestamp
- ужасный старый класс, плохо спроектированный, и был вытеснен несколько лет назад классом java.time.Instant
(всегда в UTC) или, альтернативно, java.time.OffsetDateTime
, если установлено смещение UTC.
LocalDateTime
Подходящий класс для даты с временем суток без какой-либо концепции часового пояса или смещения от UTC составляет LocalDateTime
.
Как отмечалось выше, это означает, что этот класс является не моментом, не точкой на временной шкале и должен не использоваться для отслеживания фактических точек времени, когда событие произошло в каком-то месте.
TIMESTAMP WITHOUT TIME ZONE
В базе данных, соответствующей стандарту SQL, такой как Postgres , используйте столбец с типом данных TIMESTAMP WITHOUT TIME ZONE
(не тип WITH
).
LocalDateTime ldt = myResultSet.getObject( … , LocalDateTime.class ) ;
И ...
myPreparedStatement.setObject( … , ldt ) ;
О 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 .