微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用ransack gem根据模型的实例方法对表进行排序?

如何解决如何使用ransack gem根据模型的实例方法对表进行排序?

我正在使用Rails和ransacker gem(2.3.2)构建一个可按列名过滤的表。我想根据该帐户的电子邮件地址的第一个成员过滤帐户。模型和实例方法如下所示:

class Account
 has_many :members

 def first_member_email
   members.order(created_at: :desc).first.email
 end
end

class Member
 belongs_to :account
end

我计划使用Ransack的“ sort_link”根据帐户的first_member_email实例方法进行排序。基于documentation,使用抢劫犯似乎是必经之路。像这样:

ransacker :first_member_email do |parent|
      Arel.sql(something)
 end

并在视图中:

th=sort_link @q,:first_member_email,'Created By'

但是我无法让Arel工作。要使此功能起作用的查询是什么?或者没有使用Arel的另一种方法

解决方法

您可以这样做:

# app/models/account.rb

class Account < ApplicationRecord
  scope :sort_by_first_member_email_asc,-> { sort_by(&:first_member_email) }
  scope :sort_by_first_member_email_desc,-> { sort_by(&:first_member_email).reverse }
end

如果需要,可以在合并范围内编写自定义查询。谢谢:)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。