大佬教程收集整理的这篇文章主要介绍了ruby-on-rails – 如何指定Rails 3 scope.limit – 带偏移?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我可以轻松获取最新的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)
但我想要的是
@posts = Post.published.limit(6,12)
但是这个参数的数量是错误的,AR有什么办法吗?现在我正在玩will_paginate,但它似乎是hacky使用它为此.
@posts = Post.published.limit(6).offset(5)
它将从第六个开始检索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
所以我真的不知道它如何与数组一起使用.但我显然错过了一些东西.你看到什么吗?
编辑:好尝试,但没有…;)
我不知道如果它会奏效,但是你尝试:
@posts = Post.published.limit(6..12)
?
以上是大佬教程为你收集整理的ruby-on-rails – 如何指定Rails 3 scope.limit – 带偏移?全部内容,希望文章能够帮你解决ruby-on-rails – 如何指定Rails 3 scope.limit – 带偏移?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。