3

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

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

class Customer < ActiveRecord::Base
  has_many :orders
end

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

ORDER ID| CUSTOMER NAME |...

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

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

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

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

有任何想法吗?

4

3 回答 3

4

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

Order.joins(:customer).order("customers.name asc").page(5)
于 2013-01-15T11:19:43.093 回答
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

于 2013-01-15T11:07:38.353 回答
1

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

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

Kaminari.paginate_array(orders).page(page)
于 2013-01-15T12:42:22.087 回答