金融类面试必考--大数据量的分页问题
来源:互联网 发布:mac中山有专柜吗 编辑:程序博客网 时间:2024/09/21 09:26
方法一:rownum
Oracle数据库为我们提供了两个很重要的字段:RowId和RowNumber。RowId是一个绝对的值,是针对某一行分配的一个唯一的行标识符,根据它我们可以非常迅捷地定位到某一个具体的行。它也起着主键的作用,即它是唯一的(Unique)、必有的(Mandatory)字段。RowNumber是一个相对的值,是指查询结果的行号。例如Standard标准题录表中有三条题录信息,那么每行对应的RowNumber即为1、2、3。它是一个从1开始标记的行数信息。根据RowNumber,我们就可以实现分页技术了。
但是在实施的过程中,也遇到了一个问题。最开始我认为这样写就可以了:
select * from thetable
where rownumber between ((页码-1) * 页容量 + 1) and (页码 * 页容量)
例如如果10条一页,取第二页的内容,那么就是:select * from thetable where rownumber between (2-1)*10+1 and 2*10。但这是错误的,返回结果会是一个空集合。对rownumber实施where条件查询是有限制的,只能求前多少多少行,即where rownumber<somevalue。所以只能让rownumber小于某一值,不能求中间的某一个值域。
虽然RowNumber不能按照上述的方法使用,但是依然存在别的方法来分页。如果我们求100-200行的记录,需要使用两层select语句。内层只需要先select出前100行的rowid,以便于从前200行中排除;外层select要做两件事情,一是求出前200行数据,二是排除前100行数据。这样,分页技术便实现了。
经过改造,在Oracle下分页的sql语句如下:
select * from thetable
where rowid not in(
select rowid from thetable where rownum<=(页码-1)*页容量
) and rowid in(select rowid from thetable where rownum<=页码*页容量)
参考文章:http://hi.baidu.com/echolovejose/item/8d5df144eb5584e0bcf45147
方法二:
②采用row_number解析函数进行分页(效率更高)
SELECT xx.*FROM(
SELECT t.*,row_number() over(ORDER BY o_id)AS num
FROM t_order t
)xx
WHERE num BETWEEN 5 AND 15;
--返回第5-15行数据
解析函数能用格式
函数() over(pertion by字段 order by字段);
Pertion按照某个字段分区
Order按照勒个字段排序
方法二更高效,参考文章:http://chengjunflying.iteye.com/blog/394708
另外还有动态分页方法,等复习完存储过程和游标再写。
- 金融类面试必考--大数据量的分页问题
- mysql大数据量的分页查询问题
- 大数据量下的分页
- 大数据量下的分页
- 大数据量下的分页
- Jax的大数据量分页
- Jax的大数据量分页
- 大数据量下的分页
- 大数据量下的分页
- 大数据量下的分页
- 大数据量下的分页
- 大数据量下的分页
- 面试十大必考题目!
- 大数据量下的分页 (转载)
- [转贴]大数据量下的分页
- Displaytag1.1大数据量分页的例子
- SQL2005中大数据量检索的分页
- ORACLE大数据量下的分页解决方法
- Struts2中Action的一些小结(05)
- 计算机视觉大牛
- PPPoE工作原理以及PPPoE帧格式
- Jodd功能概览
- VC6.0中18个实用小技巧
- 金融类面试必考--大数据量的分页问题
- Caused by: java.lang.NumberFormatException: Invalid double: ""
- 抽象类和接口的区别
- 数据结构12:模式匹配BF算法
- Win7 64位 Emgu.CV.CvInvoke的类型初始值设定项引发异常
- Linux select详细解读(一)
- Lucence的基本原理
- Mac OS X10.9安装的Python2.7升级Python3.3步骤详解
- 公交车上搭讪美女