我在这里有两个关联的模型:
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)