这里我总结了几种常用的数据库的分页写法,包含mysql、oracle、mongodb和django的模型。
- mysql的分页写法,相对简单一些:
1 # 返回前5行 第一个参数0,表示从第几开始, 第二个参数5表示从0开始往后取5条数据2 select * from table limit 0,53 4 # 降序5 select * from table order by field desc limit 0,5
-
oracle的分页写法:
1 # 取前20条数据2 select * from ( select A.*, rownum rn from (select * from table) A where rownum <=20 ) where rn >= 03 4 # 取8条数据,第2条到第10条 5 select * from ( select rownum as num, A.* from table A) t where t.num between 2 and 10
-
mongodb的分页写法:
1 # db表示连接数据库, table表示集合名(表),field 排序字段,order代表升序还是降序, skip、limit表示从第几条到第几条2 result = db.table.find(condition).sort([(field, order)]).skip(skip).limit(limit)
-
Django模型写法:
1 # field 排序字段,order代表升序还是降序, skip、limit表示从第几条到第几条
2 result = Table.objects.filter(**kwargs).order_by(field)[skip: skip + limit]
动态实现分页方法,只需要把相关的变量传到sql语句即可。尽管总结的比较简单,但是在开发过程中经常会用到的,写出来分享给做开发的朋友。