如何指定Rails 3 scope.limit - 带偏移量?

sbe*_*eam 16 ruby-on-rails

所以我有一些帖子,想展现ñ .. 中号在侧边栏最新的条目(这些数字在配置设定)

我可以轻松地获得最新的n条记录

class Post < ActiveRecord::Base
  default_scope :order => "created_at DESC"
  scope :published, lambda { where("blog_entries.created_at <= ?", Time.zone.now) }
  scope :latest, lambda { |n| published.limit(n) }
end

@posts = Post.latest(6)
Run Code Online (Sandbox Code Playgroud)

但我想要的是

@posts = Post.published.limit(6, 12)
Run Code Online (Sandbox Code Playgroud)

但是这给了wrong number of arguments,AR中有什么方法吗?现在我正在玩will_paginate,但看起来很难用它.

Rob*_*bin 21

好的,答案是,我认为:

@posts = Post.published.limit(6).offset(5)
Run Code Online (Sandbox Code Playgroud)

它将从第六个开始检索6个帖子.


edit2:关于极限([6,12]),我觉得很奇怪:

attr_accessor :limit_value

def limit(value)
  relation = clone
  relation.limit_value = value
  relation
end


def build_arel
    ...
    arel.take(connection.sanitize_limit(@limit_value)) if @limit_value
    ...
end


def sanitize_limit(limit)
    if limit.is_a?(Integer) || limit.is_a?(Arel::Nodes::SqlLiteral)
      limit
    elsif limit.to_s =~ /,/
      Arel.sql limit.to_s.split(',').map{ |i| Integer(i) }.join(',')
    else
      Integer(limit)
    end
  end
Run Code Online (Sandbox Code Playgroud)

所以我真的不知道它如何与数组一起工作.但我显然错过了一些东西.你看到了什么?