草庐IT

两个日期和两次之间的mySQL查询

全部标签

ruby-on-rails - ActiveRecord - 查询多态关联

我正在使用多态关联来跟踪我项目中的评论。所有非常直接的东西。我遇到的问题是基于多态关联的查询以及从Comment模型连接回它的所有者。所以...我有一个评论模型classCommenttrueend还有一个论坛主题模式:classForumTopic:commentableend我还有其他几个目前不重要的“可评论”模型。所有这些都有效。我想要做的是找到属于具有指定条件(在本例中,'featured'==true)的ForumTopic的所有评论。当我尝试使用取景器加入模型时:@comments=Comment.find(:all:joins=>:commentable:conditio

Ruby:将 unix 时间戳转换为日期

这个问题在这里已经有了答案:Howtoconvertaunixtimestamp(secondssinceepoch)toRubyDateTime?(6个答案)关闭6年前。irb>dt=Time.now.utc=>2012-04-2610:47:01UTCirb>dti=dt.to_i=>1335437221现在,如何将dti转换回日期/时间?

ruby-on-rails - 在 where 查询中查找 nil has_one 关联

这可能是一个简单的问题,但我似乎正在努力寻找一个优雅的解决方案。我有两个ActiveRecord模型类,它们之间有has_one和belongs_to关联:classItem我正在寻找一种优雅的方法来查找所有Item对象,这些对象没有与之关联的购买对象,理想情况下无需求助于boolis_purchased或Item上的类似属性。现在我有:purchases=Purchase.allItem.where('idnotin(?)',purchases.map(&:item_id))这行得通,但对我来说似乎效率低下,因为它执行两个查询(并且购买可能是一个庞大的记录集)。运行Rails3.1.

ruby-on-rails - 如何在 Rails 中验证今天之后的日期?

我有一个包含属性的ActiveRecord模型:expiry_date。我如何着手验证它,使其在今天之后(当时的当前日期)?我是Rails和ruby​​的新手,我找不到能准确回答这个问题的类似问题?我正在使用Rails3.1.3和ruby​​1.8.7 最佳答案 您的问题(几乎)得到了准确回答intheRailsguides.这是他们提供的示例代码。此类验证日期是否在过去,而您的问题是如何验证日期是否在future,但调整它应该很容易:classInvoice 关于ruby-on-rai

ruby-on-rails - 在 Ruby 中减去日期并得到以分钟为单位的差异

我如何在Ruby中减去两个不同的UTC日期,然后得到以分钟为单位的差异?谢谢 最佳答案 如果减去两个Date或DateTime对象,结果是一个Rational表示它们之间的天数。你需要的是:a=Date.new(2009,10,13)-Date.new(2009,10,11)(a*24*60).to_i#2880minutes或a=DateTime.new(2009,10,13,12,0,0)-DateTime.new(2009,10,11,0,0,0)(a*24*60).to_i#3600minutes

ruby - RSpec 是否有可能期望两个表发生变化?

RSpec预期变化:it"shouldincrementthecount"doexpect{Foo.bar}.tochange{Counter.count}.by1end有没有办法在两个表中期待变化?expect{Foo.bar}.tochange{Counter.count}.by1andchange{AnotherCounter.count}.by1 最佳答案 我更喜欢这种语法(rspec3或更高版本):it"shouldincrementthecounters"doexpect{Foo.bar}.tochange{Counte

ruby - 如何最好地在两个 float 之间的范围内创建一个随机 float

我知道我可以用rand(max)生成随机float。我试图生成一个范围内的float,这应该不难。但是例如rand(1.4512)返回0,因此rand不是用float计算的。现在我尝试了一个小技巧,将它转换为一个整数,然后在我想要的范围内随机化一个合适的数字后,将它计算回一个float......这是行不通的。我的问题是如何以更好的方式做到这一点。如果没有更好的方法,为什么这个方法不起作用?(也许对我来说太晚了,我应该在2小时前开始sleep……)。整个事情旨在成为一种计算数据库记录“位置”字段的方法,以便用户可以手动订购它们。我以前从未做过这样的事情,也许有人可以用更好的解决方案提示

Ruby - 如何获取数组中的最后两个值?

numbers=[1,2,3,4,5,6,7,8]numbers.last#=>8我需要获取最后两条记录。到目前为止我已经试过了:numbers.last-1#throwsa`NoMethodError` 最佳答案 last接受一个参数:@numbers=[1,2,3,4,5,6,7,8]@numbers.last(2)#=>[7,8]如果要删除最后两项:@numbers.pop(2)#=>[7,8]p@numbers#=>[1,2,3,4,5,6] 关于Ruby-如何获取数组中的最后两

ruby - Ruby 中 Postgres 查询的简单示例

对于我的生活,我找不到一个简单的例子来运行类似的东西“SELECT*FROMMyTable”在ruby中。我发现的所有内容都假定使用ORM或Rails。现在,我不想要ORM;我不想要Rails。我正在寻找使用pggem并执行简单查询的独立程序。 最佳答案 来自pggem文档(http://rubydoc.info/gems/pg/0.10.0/frames)require'pg'conn=PGconn.open(:dbname=>'test')res=conn.exec('SELECT1ASa,2ASb,NULLASc')res.g

ruby - 查找两个数组之间的共同值

如果我想比较两个数组并创建一个内插输出字符串,如果数组y中的数组变量存在于x中,我如何获得每个匹配元素的输出?这就是我正在尝试但未完全得到结果的方法。x=[1,2,4]y=[5,2,4]x.eachdo|num|puts"Thenumber#{num}isinthearray"ifx.include?(y.each)end#=>[1,2,4] 最佳答案 可以使用设置交集的方法&为此:x=[1,2,4]y=[5,2,4]x&y#=>[2,4] 关于ruby-查找两个数组之间的共同值,我们在