不同数据库的分页方法

  这里我总结了几种常用的数据库的分页写法,包含mysql、oracle、mongodb和django的模型。

  1. mysql的分页写法,相对简单一些:
    1  # 返回前5行 第一个参数0,表示从第几开始, 第二个参数5表示从0开始往后取5条数据
    2  select * from  table limit 0,5
    3 
    4  # 降序
    5  select * from  table  order by field desc limit 0,5
  2. oracle的分页写法:

    1 # 取前20条数据
    2 select * from ( select A.*, rownum rn from (select * from table) A where rownum <=20 ) where rn >= 0
    3 
    4 # 取8条数据,第2条到第10条 
    5 select * from ( select rownum as num, A.* from table A) t where t.num between 2 and 10
  3. mongodb的分页写法:

    1  # db表示连接数据库, table表示集合名(表),field 排序字段,order代表升序还是降序, skip、limit表示从第几条到第几条
    2  result = db.table.find(condition).sort([(field, order)]).skip(skip).limit(limit)
  4. Django模型写法:

    1  # field 排序字段,order代表升序还是降序, skip、limit表示从第几条到第几条
    2 result = Table.objects.filter(**kwargs).order_by(field)[skip: skip + limit]

    动态实现分页方法,只需要把相关的变量传到sql语句即可。尽管总结的比较简单,但是在开发过程中经常会用到的,写出来分享给做开发的朋友。

posted on 2016-10-20 17:10  logicalsky  阅读(1332)  评论(0编辑  收藏  举报

导航