metaclass: (Default)
[personal profile] metaclass
в 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"

Date: 2012-02-16 06:21 pm (UTC)
From: [identity profile] slonopotamus.livejournal.com
Я хер знает какой там у вас sql (видимо тоже fb, в котором, как выяснилось, даже лога запросов нет), в моëм sql всë есть: http://www.postgresql.org/docs/9.1/static/datatype-datetime.html#DATATYPE-DATETIME-TABLE
И с таймзоной и без таймзоны и отдельно дата без времени и отдельно время без даты.

Date: 2012-02-16 06:24 pm (UTC)
From: [identity profile] sergiej.livejournal.com
Где вы там увидели таймзон у "даты"???

Date: 2012-02-16 06:33 pm (UTC)
From: [identity profile] slonopotamus.livejournal.com
Само название ТАЙМзоны совершенно недвусмысленно намекает что она имеет отношение ко ВРЕМЕНИ. Если у нас нет ВРЕМЕНИ, то и нет смысла говорить о таймзоне.

И этим вашим Минским контрактам глубоко похер на таймзону. Не пишут в контракте в какой таймзоне он был заключен. Более того, можно сначала продать а потом в конце месяца задним числом подписать бумаги. И никого не колебет какая там была таймзона.

Ваш пример надуман.

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

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

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

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

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

Date: 2012-02-16 06:42 pm (UTC)
From: [identity profile] metaclass.livejournal.com
Ну, про это речь и идет. О том, что нужен тип "дата" :)

Date: 2012-02-16 06:50 pm (UTC)
From: [identity profile] slonopotamus.livejournal.com
Да есть в базе тип "дата". И называется он, как это ни странно, date.

Date: 2012-02-16 07:01 pm (UTC)
From: [identity profile] metaclass.livejournal.com
А в жабе java.util.Date - внезапно, содержит время, равное полночи, и таймзону.

Date: 2012-02-16 07:04 pm (UTC)
From: [identity profile] slonopotamus.livejournal.com
java.util.Date (как и java.util.Calendar) - феерический пиздец, который починен только в joda-time. Однако посыл тред-стартера (не путать с топик-стартером) был в том, что в sql нет типа "дата".

Date: 2012-02-16 07:22 pm (UTC)
From: [identity profile] sergiej.livejournal.com
Посыл в том что нет стандарта, позволяющая эту дату переделывать однозначно в жавовскую дату, и нужно тягать ещё дополнительную информацию, или забить, и читать её в стринг.

Date: 2012-02-17 05:28 am (UTC)
From: [identity profile] antontsau.livejournal.com
нинада. В контрактах очень часто пишут. В страховках так вообще обязательно - "вступает в действие с 00.00 надцатого мартобря", а привязка по месту заключения контракта (что тоже обязательный аттрибут!) или прямо указывается временная зона (AEDT какой-нибудь). Ибо оно реально работает, расколотил застрахованный мошын на 15 минут раньше или позже границы - все, контракт не катит.

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 29th, 2025 08:44 am
Powered by Dreamwidth Studios