ТЛ; др
Проверьте, какая версия JDBC поддерживается вашим драйвером JDBC.
В JDBC 4.2 и более поздних версиях вы можете делать следующее:
myPreparedStatement.setObject(
… ,
LocalDateTime.now()
)
До JDBC 4.2, см. Ответ от YCF_L .
JDBC 4.2
Начиная с JDBC 4.2, вы можете напрямую обмениваться объектами java.time с вашей базой данных. Больше не нужно использовать java.sql.Timestamp
снова.
LocalDateTime ldt = LocalDateTime.now() ; // Better to pass explicitly your desired time zone rather than rely implicitly on the JVM’s current default.
Перейдите к подготовленному выписке методом setObject
.
myPreparedStatement.setObject( … , ldt ) ;
индексирование.
LocalDateTime ldt = myResultSet.getObject( … , LocalDateTime.class ) ;
JDBC 4.1 и более ранние версии
Если ваш драйвер JDBC еще не обновлен для JDBC 4.2 или более поздней версии, см. Ответ от YCF_L .
О 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 .