草庐IT

Spark的常用SQL日期函数

全部标签

ruby-on-rails - 将日期与 rails3 中的日期时间 Created_at 进行比较

所以我正在尝试做这样的事情:today=Date.today-1todaysReport=Report.where(:created_at=>today).find_by_user_id(user.id)问题是created_at是一个日期时间,所以它找不到任何匹配项。有什么建议吗? 最佳答案 你可能想要这样的东西:yesterday=Time.now-1.dayuser=User.find(user_id)todaysReport=user.reports.where(["created_at>=?ANDcreated_at

ruby-on-rails - 如何评估年、月和日的日期差异( ruby )?

我必须在两个日期之间做一个简单的区分:Date.parse("2009-06-20")-Date.today这给出了以天为单位的日期差异。任何人都知道一种轻松地将其转换为以下格式的方法:TheeventoccurredXyears,YmonthsandZdaysago谢谢。 最佳答案 在这里找到答案:Moreprecisedistance_of_time_in_words有了这个gem:https://github.com/radar/dotiw 关于ruby-on-rails-如何评估

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

ruby - 如何访问 ruby​​ 中的(阴影)全局函数

我想知道如何从一个定义了方法fn的类访问ruby​​中的全局函数fn。我通过像这样给函数起别名来解决这个问题:deffnendclassBaraliasglobal_fnfndeffn#howtoaccesstheglobalfnherewithoutthealiasglobal_fnendend我正在寻找与c++的::类似的东西来访问全局范围,但我似乎无法找到有关它的任何信息。我想我并不清楚自己在寻找什么。 最佳答案 在顶层,def将私有(private)方法添加到Object。我能想到的三种获取顶层函数的方法:(1)使用send

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby-on-rails - Rails 如何根据日期范围创建月份数组

例子我有:range=start.to_date..(end.to_date+1.day)结束和开始是日期。如何根据这个范围创建月份数组?例子:我有日期23/1/2012和15/3/2012月份是一月、二月和火星。我想得到一个像["1/1/2012","1/2/2012","1/3/2012"]这样的数组如果范围在25/6/2012到10/10/2012之间数组将是:["1/6/2012","1/7/2012","1/8/2012","1/9/2012","1/10/2012"] 最佳答案 require'date'date_fro

ruby-on-rails - Rails 定义明天日期的方法是什么?

在Rails3.2应用程序中,我定义了一个查询以返回所有事件项:到期日期等于今天。@due_today=Event.where(:due_date=>Time.now.beginning_of_day..Time.now.end_of_day)我想修改它以返回今天和明天到期的所有事件。执行此操作的最佳方法是什么?我知道我有几个选择:Date.tomorrowDate.current.tomorrowDate.now.tomorrowDateTime.now.tomorrow.to_dateTime.now.tomorrow.to_dateDate.current+1我敢肯定还有其他人。

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p