我有一个文本文件 (CSV),其中包含来自 MySQL 的数据,它有很多字段,其中一个字段是 DateOfTransaction,其值如下 "21/08/2012"。
我编写了一个 java 程序来读取 CSV 文件并将文档插入 mongodb。
插入日期的代码
SimpleDateFormat formatter = new SimpleDateFormat("dd/MM/yyyy"); //set the date format
Date d2 = new SimpleDateFormat("dd/mm/yyyy").parse(arr[10]);
bookRenterLineItemInstance.setDateoftransaction(d2.getTime());
解析和日期对象都已正确创建,一切都很好。 但是当我查询 mongodb 集合时,它会给我落后一天的记录。
例如,如果我插入日期:"21/08/2012"
在 mongodb 中保存为:"DateOfTransaction": ISODate("2012-01-20T18:38:00Z")
我所有的查询都与这个领域有关。
请帮助确保日期不会更改并保存为 ISODate("2012-01-21T18:38:00Z") for "21/08/2012"
最佳答案
您当前尝试执行的操作存在两个问题:
要解决第一个问题,你需要改变
Date d2 = new SimpleDateFormat("dd/mm/yyyy").parse(arr[10]);
到
Date d2 = new SimpleDateFormat("dd/MM/yyyy").parse(arr[10]);
日期格式区分大小写,您试图做的是将月份解析为 **m**inute 而不是 **M**onth。在我运行的测试中,这意味着月份都是一月,我可以看到这也在您的示例中发生。此外,我注意到您的第一行代码未使用格式化程序(已正确设置)。
第二个问题是,是的,Java Date 的行为并不像您期望的那样。他们必须有一个时间组件,即使你不关心它只是为了日期。此外,他们必须有时区,因为他们有时间。
您可能无法选择迁移到高级 Joda 库,在这种情况下,有一些方法可以解决这个问题。我写了一个测试来证明这一点:
@Test
public void shouldParseDateCorrectly() throws Exception {
// Given
SimpleDateFormat format = new SimpleDateFormat("dd/MM/yyyy");
format.setTimeZone(TimeZone.getTimeZone("UTC"));
// When
Date parsedDate = format.parse("21/08/2012");
// Then
Assert.assertThat(parsedDate.toString(), is("Tue Aug 21 02:00:00 CEST 2012"));
Assert.assertThat(parsedDate.toGMTString(), is("21 Aug 2012 00:00:00 GMT"));
}
所以您可以看到我使用了正确的格式,而且还将时区设置为 UTC(因此它的偏移量为零并且没有夏令时)。然后,当您使用此格式化程序解析日期时,日期将以 UTC 时区的午夜时间出现。因为我的电脑在欧洲,当我打印这个日期时,它显示的时间是凌晨 2 点,因为这个时区比 UTC 早 2 小时。但是当我使用已弃用的 toGMTString 方法时,时间为零。
当您使用 Java 驱动程序将此日期存储到 MongoDB 中时,它会保存日期、时间和时区,即使您只关心日期。当您再次读取日期时,您需要做的是记住它们是 UTC 并适本地设置时区。
或者,您可以在不更改时区的情况下将它们存储在 MongoDB 中,前提是您始终在同一时区读入和写出它们。但是当 a) 处理超过午夜的时间和 b) 夏令时开始(或停止)时,这充满了意想不到的错误。
或者只使用 Joda-Time .
关于java - 如何在 mongodb 中插入与通过 java 从 String 读取的日期相同的日期?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20800895/
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
尝试通过RVM将RubyGems升级到版本1.8.10并出现此错误:$rvmrubygemslatestRemovingoldRubygemsfiles...Installingrubygems-1.8.10forruby-1.9.2-p180...ERROR:Errorrunning'GEM_PATH="/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/ruby-1.9.2-p180@global:/Users/foo/.rvm/gems/ruby-1.9.2-p180:/Users/foo/.rvm/gems/rub
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是