Rails 3.2
如何在控制台中找到最后记录的范围?
Distributor.find_by_id(2..last)
谢谢
答案 0 :(得分:2)
您可以这样做:
Distributor.where('id >= 2')
这也有效,但它会执行2次查询:
Distributor.where(id: 2..Distributor.last.id)
答案 1 :(得分:0)
最后(限制=零)
查找最后一条记录(如果提供参数,则为最后N条记录)。如果没有定义订单,它将按主键排序。
Person.last # returns the last object fetched by SELECT * FROM people
Person.where(["user_name = ?", user_name]).last
Person.order("created_on DESC").offset(5).last
Person.last(3) # returns the last three objects fetched by SELECT * FROM people.
http://api.rubyonrails.org/classes/ActiveRecord/FinderMethods.html
def last(limit = nil)
if limit
if order_values.empty? && primary_key
order(arel_table[primary_key].desc).limit(limit).reverse
else
to_a.last(limit)
end
else
find_last
end
end