ruby-on-rails-3 - 是否可以在Rails3中反转命名作用域?

标签 ruby-on-rails-3 named-scope

在我的Rails3模型中,我具有以下两个命名范围:

scope :within_limit,     where("wait_days_preliminary <= ? ", ::WAIT_TIME_LIMIT.to_i )
scope :above_limit,      where("wait_days_preliminary > ? ",  ::WAIT_TIME_LIMIT.to_i )

基于它们的相似性,我自然会通过反转第一个来定义第二个。

我如何在Rails中做到这一点?

最佳答案

Arel有一个not方法,您可以使用:

condition = arel_table[:wait_days_preliminary].lteq(::WAIT_TIME_LIMIT.to_i)
scope :within_limit, where(condition)     # => "wait_days_preliminary <= x"
scope :above_limit,  where(condition.not) # => "NOT(wait_days_preliminary <= x)"

关于ruby-on-rails-3 - 是否可以在Rails3中反转命名作用域?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9574959/

相关文章:

ruby-on-rails - 如何按多个字段筛选结果?

sql - 如何编写命名范围以通过传入的所有数组进行过滤,而不仅仅是通过匹配一个元素(使用 IN)

ruby-on-rails - rails 3 : Call back for when a certain object is pulled from the database (Mongo Mapper)

ruby-on-rails - 设置多态关联

ruby-on-rails - 动态 `named_scope` 取决于某些标准

mysql - Rails 4 ActiveRecord 按关联计数排序

arrays - 搜索数组元素并返回元素但保留原始类

ruby-on-rails - 使用 Tire 和 ElasticSearch 搜索多个模型

ruby-on-rails - ActiveRecord::StatementInvalid SQLite3::SQLException:没有这样的列:真:

ruby-on-rails - will_paginate 和 named_scopes