SELECT * FROM abc where rownum > 8 这样没有结构 SELECT * FROM abc where rownum < 12 这样就行 大于8的都没有小于12的竟然有...不理解啊...
慕姐4208626
浏览 349回答 3
3回答
慕工程0101907
大于不是这么用的,如果想找到从第二行记录以后的记录,当使用rownum>8是查不出记录的,原因是由于rownum是一个总是从1开始的伪列,Oracle 认为rownum> n(n>1的自然数)这种条件依旧不成立,所以查不到记录SQL> select rownum,id,name from abc where rownum >8;ROWNUM ID NAME---------- ------ ---------------------------------------------------可以使用以下的子查询方法来解决。注意子查询中的rownum必须要有别名,否则还是不会查出记录来,这是因为rownum不是某个表的列,如果不起别名的话,无法知道rownum是子查询的列还是主查询的列。SQL>select * from(select rownum no ,id,name from abc) a where no>8;-- 除了rownum其他随意写的