我在这里关联了两个模型:
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
有什么想法吗?
答案 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)