Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
1.5k views
in Technique[技术] by (71.8m points)

jpa - storing OffsetDateTime into `TIMESTAMP WITH TIME ZONE` column. Which timezone will be stored into db?

I'm testing how timestamps are stored into Oracle DB using JPA and I'm a little surprised by the result.

The oracle docs:

https://docs.oracle.com/cd/B19306_01/server.102/b14225/ch4datetime.htm

explains, that timestamp should be stored along with timestamp.

On input I have this timestamp: 2021-01-07T15:30:06.540+05:00. Application server runs in -09:00 timezone. DB server runs in +01:00. When I store into TIMESTAMP WITH TIME ZONE column, I'd expect, that timestamp with "+05:00" will be stored into db, the timezone of timestamp, but it is -09:00, the timezone of app server.

the field in entity is mapped as:

@Column(name = "g", nullable = false)
private OffsetDateTime g_parsedAsOffsetDateTimeStoredAsWithTimeZone;

and it's value is parsed from input string as

OffsetDateTime.parse(input.getA(), ISO_ZONED_DATE_TIME)

I don't think that -09:00 I see in DB is based on some interpretation of timestamp by application I use to read db with, because actually I don't live in alaska and alaska timezone was just selected as an extreme to run app server with to make sure I don't see any "correct" value by mistake.

What is to be expected when storing OffsetDateTime as such? Timezone from request or timezone of application server? Why am I seing the timezone of app server, it does not seem to make sense.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)
等待大神答复

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...