aasm_column :status
aasm do
state :unpaid, :initial => true
state :paid
state :refund
state :closed
state :cancelled
...这些是模型中的状态,我需要根据aasm_column的状态对记录进行排序。例如,我有五张唱片,它们都有不同的状态。现在,我需要得到所有的记录,如果有一个优雅的方法来实现,它们应该被排序为“无报酬”的记录,然后是“支付”的记录,等等。
发布于 2014-05-24 07:32:07
aasm和其他state_machine宝石除了为您的记录提供结构之外,什么也不做。据我所知,他们没有任何方法对数据进行优先级排序(这只是确定其state的一种方法)。
我建议您考虑让ActiveRecord来处理它(使用order):
#app/models/your_model.rb
Class Model < ActiveRecord::Base
scope :prioritize, -> { order(unpaid: :desc, paid: :asc) }
end这样你就可以打电话:
def index
@items = Model.where(values: here).prioritize
end--
当然,order方法需要工作,但我希望您能理解吗?我可以重构如果你想让我
https://stackoverflow.com/questions/23840928
复制相似问题