草庐IT

MongoDB 时区

coder 2023-10-29 原文

我写入我的 mongoDB 数据库,例如开始日期,开始日期始终是一周中的星期一(我使用并且我在欧洲中部时区)。

"startDate" : ISODate("2014-12-28T23:00:00Z"), 
"startDate" : ISODate("2015-03-29T22:00:00Z")
"startDate" : ISODate("2015-04-05T22:00:00Z"), 
"startDate" : ISODate("2015-10-25T23:00:00Z")

我很困惑,因为有时日期格式是:

2014-12-28T23:00:00Z  (sunday, 23h)

有时是:

2015-04-05T22:00:00Z (sunday, 22h)

在 Java 代码中,日期是星期一,00h -> 这没问题。 有谁知道这里发生了什么,为什么记录的时间不同以及如何防止这种情况发生?

最佳答案

夏令时

MongoDB 将日期存储在 UTC 中默认。

由于您处于中欧时区,这意味着存在一小时或两小时的差异,具体取决于日期是在 Daylight Saving Time (DST) 之内还是之外。时期。 2015 年夏令时从 3 月 29 日开始,到 10 月 25 日结束。因此,12 月 28 日有 1 小时的偏移,4 月 5 日有 2 小时的偏移。

如果您想避免这种情况,您应该在将本地日期时间值保存到 MongoDB 之前将其转换为 UTC 时间。或者,正如 Markus Mahlberg 指出的那样,在加载日期后转换为本地时间。

关于MongoDB 时区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34085053/

有关MongoDB 时区的更多相关文章

  1. ruby - 没有轨道的 ActiveRecord 时区 - 2

    我在非Rails项目中使用ActiveRecord。在Rails中,我可以这样做:config.time_zone='EasternTime(US&Canada)'config.active_record.default_timezone='EasternTime(US&Canada)'但如果我不使用rails,我该如何设置时区? 最佳答案 ActiveRecord::Base.default_timezone='EasternTime(US&Canada)' 关于ruby-没有轨道的A

  2. ruby - 将 Logstash 中的时间戳时区转换为输出索引名称 - 2

    在我的场景中,Logstash收到的系统日志行的“时间戳”是UTC,我们在Elasticsearch输出中使用事件“时间戳”:output{elasticsearch{embedded=>falsehost=>localhostport=>9200protocol=>httpcluster=>'elasticsearch'index=>"syslog-%{+YYYY.MM.dd}"}}我的问题是,在UTC午夜,Logstash在外时区(GMT-4=>America/Montreal)结束前将日志发送到不同的索引,并且索引在20小时(晚上8点)之后没有日志,因为“时间戳”是UTC。我们已

  3. ruby - 如何设置mysql2时区选项以删除查询警告 - 2

    使用mysql2做查询总是得到警告/usr/local/lib/ruby/gems/1.9.1/gems/mysql2-0.2.6/lib/active_record/connection_adapters/mysql2_adapter.rb:463:warning::database_timezoneoptionmustbe:utcor:local-defaultingto:local我确实看到了时区选项Mysql2现在支持两个时区选项::database_timezone-thisisthetimezoneMysql2willassumefieldsarealreadystored

  4. ruby - 我可以覆盖 Ruby 中的系统时区吗? - 2

    我在Ubuntu12.04上,我可以看到:$cat/etc/timezoneAmerica/Phoenix相应地,Time将返回一个非UTC时区的时间:$irb>Time.now=>2013-03-2713:44:49-0700>Time.at0=>1969-12-3117:00:00-0700我可以使用TZ环境变量覆盖系统时区:$TZ=UTCirb>Time.now=>2013-03-2720:47:19+0000>Time.at0=>1970-01-0100:00:00+0000无论如何,我可以在Ruby进程中以编程方式进行此更改吗? 最佳答案

  5. ruby - 更改纯 ruby (不是铁轨)的时区 - 2

    我正在构建一个混合UTC/PST数据源的Sinatra站点,但将在PST中查看。所以我需要一种方法来轻松地将时间对象从UTC转换为PST。没有Rails,我无法访问Time.zone、in_time_zone等。我只需要更改Time对象的时区,例如2014-08-1421:44:17+0000=>2014-08-1414:44:17-0700。首先我尝试了这个:classTimedefto_pstself.utc+Time.zone_offset('PDT')endend但这会改变实际时间戳而不是区域。我需要time.to_i和time.strftime才能工作;所以我不能改变时间戳的

  6. ruby-on-rails - 在 rails 3.2 中存储带时区的时间戳 - 2

    我正在尝试将所有时间戳及其包含的时区存储在Rails应用程序中。我对ActiveRecord将它们转换为utc很好,但是我有多个应用程序访问同一个数据库,其中一些应用程序是根据时区要求实现的。所以我想做的是像往常一样让activerecord转换我的时间戳,然后将它们写入数据库,并在时间戳后附加字符串“America/Los_Angeles”或任何适当的时区。我目前在jruby1.7.8上运行rails3.2.13,它实现了ruby​​1.9.3api。我的数据库是postgres9.2.4,与activerecord-jdbcpostgresql-adaptergem连接。列类型是带

  7. ruby - 带 ActiveSupport 的默认时区(无 Rails) - 2

    如何在ActiveSupport中设置默认时区?这是发生了什么:irb-r'rubygems'ruby-1.8.7-p174>require'active_support'ruby-1.8.7-p174>require'active_support/time_with_zone'ruby-1.8.7-p174>Time.zoneruby-1.8.7-p174>nil如何将其默认设置为当前位置? 最佳答案 在rails中,它通过rails初始化程序在environment.rb中设置Rails::Initializer.rundo|c

  8. ruby - 如何使用 Ruby 和 MongoId 正确保存时区? - 2

    如果这有点菜鸟问题,请原谅:我有一个应用程序,用户可以在其中设置自己的个人资料中的时区。当有人添加阵容(应用特定术语)时,我执行以下操作:time=ActiveSupport::TimeZone.new(user.timezone).parse("Wednesday,26October,201113:30:00")#Thisoutputs:2011-10-2613:30:00+0200-validaccordingtotheuserselectedTZ然后我保存阵容:Lineup.create({:date=>time.gmtime,:uid=>user._id,:pid=>produ

  9. ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB - 2

    我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

  10. ruby - 使用 mongodb/mongoid 运行时更改模型 - 2

    我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

随机推荐