oracle中的rownum属性在where语句中大于号不起作用SELECT * FROM abc where rownum > 8这样没有结构SELECT * FROM abc where rownum < 12 这样就行 大于8的都没有小于12的竟然有.....
来源:学生作业帮助网 编辑:作业帮 时间:2024/06/27 12:27:22
![oracle中的rownum属性在where语句中大于号不起作用SELECT * FROM abc where rownum > 8这样没有结构SELECT * FROM abc where rownum < 12 这样就行 大于8的都没有小于12的竟然有.....](/uploads/image/z/15131385-9-5.jpg?t=oracle%E4%B8%AD%E7%9A%84rownum%E5%B1%9E%E6%80%A7%E5%9C%A8where%E8%AF%AD%E5%8F%A5%E4%B8%AD%E5%A4%A7%E4%BA%8E%E5%8F%B7%E4%B8%8D%E8%B5%B7%E4%BD%9C%E7%94%A8SELECT+%2A+FROM+abc+where+rownum+%3E+8%E8%BF%99%E6%A0%B7%E6%B2%A1%E6%9C%89%E7%BB%93%E6%9E%84SELECT+%2A+FROM+abc+where+rownum+%3C+12+%E8%BF%99%E6%A0%B7%E5%B0%B1%E8%A1%8C+%E5%A4%A7%E4%BA%8E8%E7%9A%84%E9%83%BD%E6%B2%A1%E6%9C%89%E5%B0%8F%E4%BA%8E12%E7%9A%84%E7%AB%9F%E7%84%B6%E6%9C%89.....)
oracle中的rownum属性在where语句中大于号不起作用SELECT * FROM abc where rownum > 8这样没有结构SELECT * FROM abc where rownum < 12 这样就行 大于8的都没有小于12的竟然有.....
oracle中的rownum属性在where语句中大于号不起作用
SELECT * FROM abc where rownum > 8
这样没有结构
SELECT * FROM abc where rownum < 12
这样就行 大于8的都没有小于12的竟然有.....
oracle中的rownum属性在where语句中大于号不起作用SELECT * FROM abc where rownum > 8这样没有结构SELECT * FROM abc where rownum < 12 这样就行 大于8的都没有小于12的竟然有.....
大于不是这么用的,如果想找到从第二行记录以后的记录,当使用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其他随意写的