java.time
В современном подходе используются классы java.time , которые вытеснили утомительные устаревшие классы даты и времени, включенные в самые ранние версии Java.
Класс java.sql.Timestamp
является одним из тех устаревших классов. Больше не нужен. Вместо этого используйте Instant
или другие классы java.time напрямую с вашей базой данных, используя JDBC 4.2 и более поздние версии.
Класс Instant
представляет момент на временной шкале в UTC с разрешением наносекунд (до девяти (9) цифр десятичного знака). доля).
Instant instant = myResultSet.getObject( … , Instant.class ) ;
Если вам необходимо взаимодействовать с существующим Timestamp
, немедленно преобразуйте его в java.time с помощью новых методов преобразования, добавленных к старым классам.
Instant instant = myTimestamp.toInstant() ;
Для настройки на другой часовой пояс укажите часовой пояс как ZoneId
объект. Укажите правильное имя часового пояса в формате continent/region
, например America/Montreal
, Africa/Casablanca
или Pacific/Auckland
. Никогда не используйте 3-4-буквенные псевдозоны, такие как EST
или IST
, поскольку они не истинных часовых поясов, не стандартизированы и даже не уникальны (!).
ZoneId z = ZoneId.of( "America/Montreal" ) ;
Применить к Instant
для создания объекта ZonedDateTime
.
ZonedDateTime zdt = instant.atZone( z ) ;
Чтобы сгенерировать строку для отображения пользователю, найдите Переполнение стека для DateTimeFormatter
, чтобы найти множество обсуждений и примеров.
Ваш вопрос на самом деле о том, чтобы идти в другом направлении, от ввода пользовательских данных до объектов даты и времени. Обычно лучше разбить ввод данных на две части: дату и время суток.
LocalDate ld = LocalDate.parse( dateInput , DateTimeFormatter.ofPattern( "M/d/uuuu" , Locale.US ) ) ;
LocalTime lt = LocalTime.parse( timeInput , DateTimeFormatter.ofPattern( "H:m a" , Locale.US ) ) ;
Ваш вопрос неясен. Хотите ли вы интерпретировать дату и время, введенные пользователем, в UTC? Или в другом часовом поясе?
Если вы имели в виду UTC, создайте OffsetDateTime
со смещением, используя константу для UTC, ZoneOffset.UTC
.
OffsetDateTime odt = OffsetDateTime.of( ld , lt , ZoneOffset.UTC ) ;
Если вы имели в виду другой часовой пояс, объедините вместе с объектом часового пояса a ZoneId
. Но какой часовой пояс? Вы можете обнаружить часовой пояс по умолчанию. Или, если это необходимо, вы должны подтвердить пользователю свое намерение.
ZonedDateTime zdt = ZonedDateTime.of( ld , lt , z ) ;
Чтобы получить более простой объект, который по определению всегда находится в UTC, извлеките Instant
.
Instant instant = odt.toInstant() ;
... или ...
Instant instant = zdt.toInstant() ;
Отправьте в свою базу данных.
myPreparedStatement.setObject( … , instant ) ;
О java.time
Платформа java.time встроена в Java 8 и более поздние версии. Эти классы вытесняют проблемные старые устаревшие классы даты и времени, такие как java.util.Date
, Calendar
и & SimpleDateFormat
.
Проект Joda-Time , находящийся сейчас в режиме обслуживания , рекомендует перейти на классы java.time .
Чтобы узнать больше, см. Oracle Tutorial . И поиск переполнения стека для многих примеров и объяснений. Спецификация JSR 310 .
Где получить классы java.time?
Проект ThreeTen-Extra расширяет java.time дополнительными классами. Этот проект является полигоном для возможных будущих дополнений к java.time. Здесь вы можете найти несколько полезных классов, таких как Interval
, YearWeek
, YearQuarter
и more .