Rails在控制台中查找范围

时间:2014-04-08 19:03:40

标签: ruby-on-rails ruby-on-rails-3.2

Rails 3.2

如何在控制台中找到最后记录的范围?

Distributor.find_by_id(2..last)

谢谢

2 个答案:

答案 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

https://github.com/rails/rails/blob/4e823b61190388219868744a34dcfe926bad511c/activerecord/lib/active_record/relation/finder_methods.rb#L157