基于Rails中的关联排序和分页记录

时间:2013-01-15 10:43:59

标签: ruby-on-rails-3 activerecord associations

我在这里关联了两个模型:

class Order < ActiveRecord::Base
  belongs_to :customer
  ...
end

class Customer < ActiveRecord::Base
  has_many :orders
end

客户可以拥有多个订单,订单可以属于一个客户。问题是我正在显示一个列出的表格,其中显示以下字段值

ORDER ID| CUSTOMER NAME |...

客户名称是指客户[:name] - 我发现您可以使用find方法进行排序并传入类似的连接:

Order.find(:all, :joins => :customer, :order => 'customer.name asc')

但是我需要在这里对结果进行分页,似乎我不能做这样的事情 - 我在这里使用Kaminari宝石进行分页:

Order.find(:all, :joins => :customer, :order => 'customer.name asc').page(5) 
# doesn't work throws an error nomethoderror on page

有什么想法吗?

3 个答案:

答案 0 :(得分:4)

您应该使用“新”Rails 3查询界面:

Order.joins(:customer).order("customers.name asc").page(5)

答案 1 :(得分:2)

您可以这样做:

Order.joins(:customer).select('orders.*, customers.name as customers_name').order('customers_name ASC').page(5)

与Kaminari宝石合作。 您还将在每个对象结果上使用customers_name方法。
您可以在此处找到有关选择方法的更多信息http://guides.rubyonrails.org/association_basics.html

答案 2 :(得分:1)

'page'适用于Kaminari,而不是Order的方法

orders = Order.joins(:customer).order("customers.name asc")

Kaminari.paginate_array(orders).page(page)