今天遇到一个关于“查询指定行数的数据”的sql查询语句问题,突然发现以前没怎么接触过,刚才想起来了,赶紧看了下文档,又上网搜了下,有了下面的东西,不知道有没有什么地方不对?
oracle:
先看一下文档中关于any和all的例子,很不错噢。
Any
示例:
select * from emp where sal>ANY(select sal from emp where deptno=30) and deptno<>30;
--找出比deptno=30的员工最低工资高的其他部门的员工
ALL
select * from emp where sal>ALL(select sal from emp where deptno=30) and deptno<>30;
--找出比deptno=30的员工最高工资高的其他部门的员工
查询指定行数的数据
SELECT <字段列表> from <table_name> WHERE ROWNUM<行数;
示例:
select * from emp where rownum<=10;--查询前10行记录
注意ROWNUM只能为1 因此不能写 select * from emp where rownum between 20 and 30;
要查第几行的数据可以使用以下方法:
select * from emp where rownum<=3 and empno not in (select empno from emp where
rownum<=3);
结果可