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



我在这里有两个关联的模型:

class Order < ActiveRecord::Base
  belongs_to :customer
  ...
end
class Customer < ActiveRecord::Base
  has_many :orders
end

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

ORDER ID| CUSTOMER NAME |...

Customer name指的是Customer [: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

任何想法?

您应该使用"new" Rails 3查询接口:

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

你可以这样做:

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

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

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

相关内容

  • 没有找到相关文章

最新更新