为了账号安全,请及时绑定邮箱和手机立即绑定

为什么我这个orownum属性在where语句中大于号不起作用?是什么原因呢?

为什么我这个orownum属性在where语句中大于号不起作用?是什么原因呢?

慕姐4208626 2021-08-25 18:15:01
SELECT * FROM abc where rownum > 8这样没有结构SELECT * FROM abc where rownum < 12这样就行 大于8的都没有小于12的竟然有...不理解啊...
查看完整描述

3 回答

?
慕工程0101907

TA贡献1887条经验 获得超5个赞

大于不是这么用的,如果想找到从第二行记录以后的记录,当使用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其他随意写的

查看完整回答
反对 回复 2021-08-30
?
慕虎7371278

TA贡献1802条经验 获得超4个赞

rownum是指对你的查询结果集进行的编号。
<12意思就是返回前11条记录,>8 意思是返回第9条以上的记录,为什么这样永远不会有返回,是因为每次取回的记录都是当作第一条,自然<8, 然后被滤掉,所以不会有返回值。

查看完整回答
反对 回复 2021-08-30
  • 3 回答
  • 0 关注
  • 348 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信