首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AASM:根据aasm_column分类记录

AASM:根据aasm_column分类记录
EN

Stack Overflow用户
提问于 2014-05-24 03:07:30
回答 1查看 480关注 0票数 1
代码语言:javascript
复制
aasm_column :status  

aasm do
  state :unpaid, :initial => true
  state :paid
  state :refund
  state :closed
  state :cancelled
...

这些是模型中的状态,我需要根据aasm_column的状态对记录进行排序。例如,我有五张唱片,它们都有不同的状态。现在,我需要得到所有的记录,如果有一个优雅的方法来实现,它们应该被排序为“无报酬”的记录,然后是“支付”的记录,等等。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-24 07:32:07

aasm和其他state_machine宝石除了为您的记录提供结构之外,什么也不做。据我所知,他们没有任何方法对数据进行优先级排序(这只是确定其state的一种方法)。

我建议您考虑让ActiveRecord来处理它(使用order):

代码语言:javascript
复制
#app/models/your_model.rb
Class Model < ActiveRecord::Base
    scope :prioritize, -> { order(unpaid: :desc, paid: :asc) }
end

这样你就可以打电话:

代码语言:javascript
复制
def index
    @items = Model.where(values: here).prioritize
end

--

当然,order方法需要工作,但我希望您能理解吗?我可以重构如果你想让我

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23840928

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档