jjzjj

java - 我应该将时区与 Postgres 和 JDBC 的时间戳分开存储吗?

coder 2024-03-11 原文

似乎(也许我错了)如果您想保留 JDBC 和 Postgres 发生某些事情时的时区,您需要将时区与时间戳分开存储。

也就是说,我更愿意给我的 ORM/JDBC/JPA 一个带有时区 America/New_York 的 Java Calendar(或 Joda DataTime) > 到 Postgres timestampz 字段。并且无论服务器时区(或默认为 UTC)如何,我都希望在检索时返回一个带有时区 America/New_YorkCalendar。但只要看看大多数 JDBC 代码(以及依赖于它但不会发生的事情)。

这是正确的吗?

当 postgres 支持时,我需要将 tz 存储在另一个字段中,这似乎很荒谬。

因此似乎只有两个选择:

  1. 选择 timestampz Postgres 列作为 java.util.String 并解析它。
  2. 将时区存储为单独的字段。

选项一和选项二需要某种类型的转换拦截器用于我的 SQL 映射/ORM 库。

  • JDBC 的最佳解决方案是什么?
  • JPA 的最佳解决方案是什么(如果不同于 JDBC)?

最佳答案

当您存储带有时区的时间戳 (timestamptz) 时,它会转换为 UTC 以存储在数据库中。检索时,它会转换为客户端的当前时区,而不是它最初所在的时区。基本上,它是一个时间点。

还有timestamp without time zone(时间戳)。这不受转换影响,但带有时间戳。如果您存储一个 timestamp 并将您的客户端时区设置为 UTC,然后在客户端时区为“+08:00”时检索它,您将获得相同的值。这是您想要的一半,因为它保留了原始时间值。

名称和行为很糟糕且令人困惑,但由 SQL 标准设置。

如果您希望记录特定时区的时间点,则必须单独存储时区。我建议将其存储为 INTERVAL 并使用 CHECK 约束将其限制为 colname BETWEEN INTERVAL '-12' HOUR + INTERVAL '1' SECOND AND INTERVAL '12' 小时。该定义拒绝 -12:00 并接受 +12:00;我不完全确定这是正确的,所以检查一下。

您可以存储该时区本地时间的 timestamp(我可能会这样做),或者存储事件发生时 UTC 时间的 timestamptz发生加上一个偏移量,让您可以将其转换为本地时间。

两者都适用于 JDBC。对于 JPA,这将取决于您的提供者对间隔类型的理解和映射程度。理想情况下,您希望实体中有一个 transient 生成字段,该字段使用存储在数据库中的 timestampinterval 重建您想要的 Calendar 实例。

关于java - 我应该将时区与 Postgres 和 JDBC 的时间戳分开存储吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12331962/

有关java - 我应该将时区与 Postgres 和 JDBC 的时间戳分开存储吗?的更多相关文章

  1. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  2. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  3. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  4. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  5. ruby-on-rails - 如何将验证与模型分开 - 2

    我有一些非常大的模型,我必须将它们迁移到最新版本的Rails。这些模型有相当多的验证(User有大约50个验证)。是否可以将所有这些验证移动到另一个文件中?说app/models/validations/user_validations.rb。如果可以,有人可以提供示例吗? 最佳答案 您可以为此使用关注点:#app/models/validations/user_validations.rbrequire'active_support/concern'moduleUserValidationsextendActiveSupport:

  6. ruby-on-rails - Ruby 检查日期时间是否为 iso8601 并保存 - 2

    我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby​​是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查

  7. ruby-on-rails - 将 Ruby 中的日期/时间格式化为 YYYY-MM-DD HH :MM:SS - 2

    这个问题在这里已经有了答案:Railsformattingdate(4个答案)关闭4年前。我想格式化Time.Now函数以显示YYYY-MM-DDHH:MM:SS而不是:“2018-03-0909:47:19+0000”该函数需要放在时间中.现在功能。require‘roo’require‘roo-xls’require‘byebug’file_name=ARGV.first||“Template.xlsx”excel_file=Roo::Spreadsheet.open(“./#{file_name}“,extension::xlsx)xml=Nokogiri::XML::Build

  8. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  9. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  10. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

随机推荐