metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2012-02-16 12:54 am

Ох, какой ад

в Java c датой и временем.
Конкретно, чтобы на Clojure засунуть в jdbc параметр дату, пришлось перерыть весь гугл, исходники jaybird (firebird jdbc драйвера), внутренности joda-time и ее кложурной обертки clj-time

http://www.paullegato.com/blog/clojure-joda-sql-date-time/

(defn to-sql-date [date]
"Convert any Joda-readable date object (including a string) to a java.sql.Date"
(java.sql.Date. (.. (LocalDate. date) toDateMidnight toInstant getMillis)))

Основной затык - только в org.joda.time.LocalDate нормально сделана дата, без времени и временных зон. А jdbc драйвер понимает только java.sql.Date и вроде еще пару вариаций на тему "эпоха в long"

[identity profile] slonopotamus.livejournal.com 2012-02-16 06:49 pm (UTC)(link)
Когда в лядском sql хранится лядская дата без времени, утверждается, что у неë нет понятия таймзоны. Вааще нет. И не нужно думать о таймзоне когда делается распечатка контракта. Надо просто печатать "2012-01-01".

[identity profile] sergiej.livejournal.com 2012-02-16 07:19 pm (UTC)(link)
Вы что, издеваетесь? В этом и проблема что сколько бы правильно база дату не записывала, в жабе Дата это будет полночь ЛОКАЛЬНОГО времени. То есть получая вашу дату из базы жабовскому приложению нужно гадать для какого же пояса дату создавать.

[identity profile] slonopotamus.livejournal.com 2012-02-16 07:26 pm (UTC)(link)
Это кривизна жабской Даты, а вовсе не sql'я.

[identity profile] sergiej.livejournal.com 2012-02-16 07:54 pm (UTC)(link)
У жабы проблема это факт, но у жабы и отмазка простая - в отсутствиии единого стандарта получается кривой java.sql.Date, который не знает что "с той стороны" за дата имеется в виду.
Кроме того со стороны джавы проблема легко решается расширением типа даты.