create table student (ID char(6), name VARCHAR2(100));
insert into student values('200001','张一');
insert into student values('200002','王二');
insert into student values('200003','李三');
insert into student values('200004','赵四');
insert into student values('200005','赵6');
insert into student values('200006','赵5');
------------------------------------------------------
select * from student where rownum=1;-- 可以
select * from student where rownum=2;-- 不可以(rownum = n为false,其中 n > 1)
select * from student where rownum>1;-- 不可以
select * from student where rownum>2;-- 不可以(rownum > n为false, 其中 n任意)
select * from student where rownum<3;-- 可以
select * from student where rownum<0;-- 可以(rownum < n为true,其中 n任意)
------------------------------------------------------
select * from
(
select rownum no,id,name from student where rownum<=3
)
where no >=2;-- 数据量大时有效率问题
select rownum, t.* from student t order by t.name;--(1)
select rownum, t.* from student t;--(2)
-- 以上两行可以看出,rownum为插入时的顺序编号
-- 自然而然,先取出有序的结果集再次在新表上作用rownum就能获得要的结果(可以理解为插入虚表时的顺序编号么?^_^)
select v.*, rownum
from
(
select * from student order by name
)v;
-- 有人认为给name加上索引或者主键,便可以打乱表数据原来插入顺序(即rownum)以新的方式排序以获得新的rownum
create index idx_name on STUDENT (name);
-- 并没有变化,删除索引上主键
drop index IDX_NAME;
alter table STUDENT add constraint key_name primary key (NAME);
-- 结果证明有效,(1)(2)两句都按照1-6的rownum名字顺序分别为插入顺序和字幕顺序
alter table STUDENT drop constraint KEY_NAME cascade;
-- 去掉主键,验证又恢复了初始状态,再来看看主键的问题,这次创建唯一主键
create unique index inx_name on STUDENT (name);
-- 唯一主键依然无效,删除。试验完毕
drop index INX_NAME;
到此,对于oracle分页排序,排序取若干行数据等问题基本就清楚了,至于为什么加索引不能达到预期目的的理由是什么,还需要进一步学习。
参考资料:http://www.cnblogs.com/temptation/archive/2007/05/16/748897.html
分享到:
相关推荐
oracle rownum和distinct
内涵oracle rownum的详细讲解。
oracle rownum
oracle 的rownum和咱们平时用的sqlserver的区别,其中好多的不一样!
oracle rownum 使用小技巧 里面包含分页
Oracle Rownum的使用与JSP分页显示的实现.pdf
oracle 分页查询 使用ROWNUM技巧及陷阱
ORACLE 中ROWNUM用法总结 整理版本,详细明了
对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<、、!=),并非说用>,>=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来...
Oracle中rownum的使用
在本篇文章里小编给大家分享的是关于mysql类似oracle rownum写法以及相关实例内容,需要的朋友们可以学习下。
sql语句中select top n与oracle的rownum与mysql的limit 取前几条数据sql简单用法
关于oracle的rownum关于oracle的rownum关于oracle的rownum关于oracle的rownum关于oracle的rownum
Hint.pdf Oracle中rowid与rownum的使用.pdf Oracle优化 之 索引.pdf Oracle优化器.pdf STATSPACK详解.pdf 学用ORACLE_AWR和ASH特性.pdf 执行计划.pdf
主要介绍了ORACLE数据库中ROWNUM用法详解,对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,且rownum不能以任何表的名称作为前缀,需要的朋友们下面随着小编来一起学习学习吧
一、oracle中rownum 用于从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,而且rownum不能以任何表的名称作为前缀。 1、rownum 对于
主要介绍了Oracle中使用Rownum分页详细例子,本文将分别展示使用rownum伪列和row_number()分析函数来完成Oracle数据分页操作的具体使用方法,需要的朋友可以参考下
oracle rownum
oracle中rownum的用法及解说,主要说明了rownum的用法,让人看了很清楚.