You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Inserting timestamp of type Instant, to column of type TIMEZONE should store exact Instant value, without introducing timezone offsets
Actual behavior
being e.g. in CET/CEST timezone and
storing Instant.ofEpochSecond(1L)
stores in DB: 1970-01-01 01:00:01.000000 instead of 1970-01-01 00:00:01.000000
1 hr difference while in CET
storing Instant.parse("2018-04-08T19:52:29Z")
stores in DB: 2018-04-08 21:52:29.000000 instead of 2018-04-08 19:52:29.000000
2 hr difference while in CEST
Storing Instants in TIMESTAMP with time zone columns seems to work. But it is very confusing.
Reasoning
Instant type is supposed to be a time-zone agnostic moment in time. The same goes for the TIMESTAMP type in Postgres.
Binding time-zone agnostic type with explicitly time-zone aware TIMESTAMP with time zone type seems to be a mistake.
@getquill/maintainers
The text was updated successfully, but these errors were encountered:
Is your JVM running in the CEST tz? JDBC drivers typically pick the current machine timezone, which unfortunately leads to such interactions. In the commit you linked, Instant is converted to a java.sql.Timestamp. There's still an open discussion in pgjdbc about supporting Instant natively, e.g. pgjdbc/pgjdbc#1325 (comment)
Also see that in zio-archive/zio-jdbc#182 you probably need to use TIMESTAMP WITH TIME ZONE if you want the correct behavior currently.
I also reached the conclusion that I need to have TIMESTAMP WITH TIME ZONE (see Workaround), but it is very disappointing and counter intuitive (see Reasoning)
Version: 4.5.0-4.8.5
Module:
quill-jdbc
Database:
postgres
16.3
Expected behavior
Inserting timestamp of type
Instant
, to column of typeTIMEZONE
should store exact Instant value, without introducing timezone offsetsActual behavior
being e.g. in CET/CEST timezone and
storing
Instant.ofEpochSecond(1L)
stores in DB:
1970-01-01 01:00:01.000000
instead of1970-01-01 00:00:01.000000
1 hr difference while in CET
storing
Instant.parse("2018-04-08T19:52:29Z")
stores in DB:
2018-04-08 21:52:29.000000
instead of2018-04-08 19:52:29.000000
2 hr difference while in CEST
Issue introduction
The issue has been introduced here:
8117a0e#diff-5161e16f0f0a107bd28613fe49aa063e2e7390ec87a61c5a8fd540ca191f67beR83
Workaround
Storing
Instant
s inTIMESTAMP with time zone
columns seems to work. But it is very confusing.Reasoning
Instant
type is supposed to be a time-zone agnostic moment in time. The same goes for the TIMESTAMP type in Postgres.Binding time-zone agnostic type with explicitly time-zone aware
TIMESTAMP with time zone
type seems to be a mistake.@getquill/maintainers
The text was updated successfully, but these errors were encountered: