作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个用户和一个付款模型。用户有多个付款,一次付款有一个用户。为了确定用户是否有有效的付款,我使用以下方法:
用户.rb
def payment_active?
payments.where("? >= made_at and ? <= valid_until", DateTime.now, DateTime.now).any?
end
我想定义一个返回活跃付款用户的范围,我想出了这个:
用户.rb
def self.active_users
User.all.select {|u| u.payment_active?}
end
编写这样一个作用域的合适、更有效的方法是什么?
最佳答案
您可以执行以下操作:
scope :with_active_payments, ->(datetime = nil) {
includes(:payments).where('payments.made_at >= :now AND :now <= payments.valid_until', now: datetime || DateTime.current)
}
DateTime.current
正确使用您当前的时区。.joins(: payments)
(而不是 include)可以使作用域返回非唯一的用户列表User.with_active_ payments(DateTime.current - 1.months)
关于ruby-on-rails - 如何尽可能高效地编写 Rails 模型关系范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21866256/
我知道在 KDB 中,如果您有一个列表,例如... l:`apples`oranges`pears` 您可以像下面这样进行 N 次随机选择: 9?l 但是如何尽可能均匀地选择列表中的每个项目? 最佳答
我真的厌倦了它。我有一个高级 Web 应用程序依赖于大量 Javascript 库(jQuery、jQueryUI、OpenLayers、highcharts、EJSChart 等等)。不用说,Int
我是一名优秀的程序员,十分优秀!