应用WillPaginate分页

应用WillPaginate分页

    博客分类:
  • Ruby && RoR
Rails SQL Ruby

WillPaginate这个插件很棒,以至于其取代了Rails中原有的Paginate方法,虽然看上其很简单,其实还是有不少技巧的,本篇用来记录我遇到的或者使用到的一些tips。

1.直接使用paginate
这个比较简单,也是使用的最多的,如下:

Ruby代码
  1. def self.get_all_items_in_catelog( catelog_id,page,per_page="10")  
  2.   paginate :per_page => per_page, :page => page,  
  3.     :conditions =>["catelog_id = ? and caiji > 0",catelog_id],  
  4.     :order => 'created_at DESC ,updated_at  DESC'  
  5. end 

 2.使用Model.paginate_by_sql
有的时候,你需要的SQL用Rails拼的时候有些不方便,这个时候可以考虑使用paginate_by_sql来实现,这个没啥好说的,你需要什么样的SQL直接写就可以了,例如:
  #排行榜列表

Ruby代码
  1. def self.get_all_items_in_rank(rank_id, page,per_page="10")  
  2.     Book.paginate_by_sql ["SELECT DISTINCT `books`.* FROM `books` LEFT OUTER JOIN `ranksorts`
  3. ON (`books`.`prodid` = `ranksorts`.`prodid`) LEFT OUTER JOIN `ranks` 
  4. ON (`ranks`.`id` = `ranksorts`.`rank_id`) WHERE (ranks.id = ?)
  5. ORDER BY books.updated_at DESC,books.created_at DESC", rank_id],  
  6.       :page => page, :per_page => per_page  
  7. end  

还有其他的一些小技巧,慢慢添加,你如果有类似的技巧,期待您的分享。。


你可能感兴趣的:(应用WillPaginate分页)