2013-01-17 16 views

回答

0

這是一個精簡版,我最終提出了。

def page_num 
    number_before = self.class.where(recipe_id: recipe.id).gte(created_at: created_at).count.to_f 
    number_on_page = self.class.default_per_page 
    (number_before/number_on_page).ceil 
end 
0

如果使用Mongoid 3,這種方法做這項工作:

class User 
    include Mongoid::Document 

    ... 

    def page_num(options = {}) 
    field = options[:by] || :_id 
    order = options[:order] || :asc 
    per = options[:per] || self.class.default_per_page 

    operator = (order == :asc) ? field.to_sym.lte : field.to_sym.gte 
    (self.class.where(operator => read_attribute(field)).order_by("#{field} #{order}").count.to_f/per).ceil 
    end 

    ... 
end 

希望這有助於。

相關問題