您的位置:首页 > 数据库 > Oracle

oracle sql 带order by ss desc 进行的分页注意事项

2017-05-09 00:00 465 查看
select * from (
select * from(
select   ROWNUM ROWNUM_,curtab.* from (

select  * from service
order by asid desc /* order by 一定要放到内层*/
) curtab
)cub  where ROWNUM_ <= 10
) currtable where ROWNUM_ >= 6


如果这里的sql是不带order by的sql,则查询结果没有任何问题。

但是,如果sql中带有order by,则会引起混乱,即相同记录会出现在不同页中。但是,这种混乱的出现通常是在下面的情况下:

1、纪录数足够多(如果表中有lob字段更好:P)

2、插入记录数大于3页,每页最好10+条记录

3、order by字段至少需要有2个值

4、具备相同order by字段的记录数大于3页

5、插入记录后,最好做删除、修改操作,然后再插入记录。保证记录在磁盘环境中的顺序是无序的。

6、如果满足上述条件,但还没有出现混乱现象,则适当的加大纪录数。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: