ROWNUM伪列:
1、使用SELECT语句返回的结果集,希望按特定条件查询前N条记录,可以使用伪列ROWNUM。ROWNUM是对结果集加一个伪列,先查到结果集后再加上一个列,是符合条件结果的序列号;从1开始排起,只能用< > = !=这些比较符合。
ROWNUM对于 等于 某值的查询条件,比如查询第一条记录,可以使用ROWNUM=1作为条件;但是如果查询第二条记录写ROWNUM=2则查询不到数据,ROWNUM的=判断只对于1有效;
2、同理,查询 大于 某值的查询条件,ROWNUM>n(n>1的自然数)这种条件不成立;那如何查询第一行以后的记录呢?
solution:用子查询解决,但是必须为rownum设置别名,"select * from (select rownum no ,id,name from table1) where no >1";
3、ROWNUM对于 小于 某值的查询是可以的,select * from table1 where rownum<3
4、ROWNUM和排序
Oracle中rownum是在取数据时产生的序号,想对指定排序的数据指定rownum行数据就要做处理了:
"select rownum,id,name from table1 order by name",查询结果按name排序,但是rownum不是按1、2、3...排列,而是按记录插入时的顺序给记录排号;
solution:使用子查询 ,select rownum ,id,name from(select * from table1 order by name)
1、使用SELECT语句返回的结果集,希望按特定条件查询前N条记录,可以使用伪列ROWNUM。ROWNUM是对结果集加一个伪列,先查到结果集后再加上一个列,是符合条件结果的序列号;从1开始排起,只能用< > = !=这些比较符合。
ROWNUM对于 等于 某值的查询条件,比如查询第一条记录,可以使用ROWNUM=1作为条件;但是如果查询第二条记录写ROWNUM=2则查询不到数据,ROWNUM的=判断只对于1有效;
2、同理,查询 大于 某值的查询条件,ROWNUM>n(n>1的自然数)这种条件不成立;那如何查询第一行以后的记录呢?
solution:用子查询解决,但是必须为rownum设置别名,"select * from (select rownum no ,id,name from table1) where no >1";
3、ROWNUM对于 小于 某值的查询是可以的,select * from table1 where rownum<3
4、ROWNUM和排序
Oracle中rownum是在取数据时产生的序号,想对指定排序的数据指定rownum行数据就要做处理了:
"select rownum,id,name from table1 order by name",查询结果按name排序,但是rownum不是按1、2、3...排列,而是按记录插入时的顺序给记录排号;
solution:使用子查询 ,select rownum ,id,name from(select * from table1 order by name)