oracle rownum 查询条件分开

ahujyy 2008-07-27 02:02:31
select * from (select rownum no,id,name from student where rownum<=3 ) where no >=2;
为什么别名的那个条件不能和rownum用and连接放在内层,把外层去掉啊
select rownum no,id,name from student where rownum<=3 and no >=2;
...全文
200 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
Yanbin_Q 2008-07-28
  • 打赏
  • 举报
回复
楼主可以看我整理过一个关于 rownum 的东西

为什么Oracle的伪列rownum不支持>,>=,=,between...and,而都用<比较
Yanbin_Q 2008-07-28
  • 打赏
  • 举报
回复
rownum 是过滤之后的记录编号

select * from table1 where rownum>1 查不到记录就这么回事
比如记录是
aa
bb
cc
dd
ee

如果你觉得rownum>1 应该能查出
bb
cc
dd
ee

其实此时 bb 所对应用的 rownum才是1,所以无法确定记录
lxxzhy 2008-07-28
  • 打赏
  • 举报
回复
rownum的话,rownum一定要包含1,怎么理解呢?
在where clause中,一般是这样的形式:
where condition A
and condition B
and ...
and rownum <= x

oracle处理的机制是,把所有rownum的条件过滤掉之后,形成了一个结果集,结果集中每一行有个一虚拟的序号(就是rownum的值),但这个虚拟的序号不是固定不变的,例如:
结果集为:
id
aaa
bbb
ccc
ddd
此时: aaa对应的rownum为1, bbb对应的rownum为2,如此类推.
当你的where clause中出现:
1. rownum = 1
oracle会在这个结果集的基础上每一行去检测rownum的值,显然只有aaa符合,因此只返回aaa那一行.
2. rownum <= 3
oracle同样在结果集中每一行去检测rownum的值,显然aaa bbb ccc符合,因此返回3行.

3. rownum = 2
oracle在检测第一行时发现第一行aaa的rownum不等于2,因此把此行从结果集中去掉,然后重新生成结果集如下:
id
bbb
ccc
ddd
此时,rownum就会重新生成,也就是bbb为1,ccc为2ddd为3.
这样的话,当在检测bbb这一行的时候,发现它的rownum是1,也不符合条件(rownum = 2),所以又把这行从结果集中去掉了,如此类推,因此你得到结果是一行也select不出来.
4. rownum >= x (x 不等于1)
这种条件得出的结果也是一行也没有的,可以根据第3种情况自己推算一下.

所以,你在网上搜到很多关于rownum的资料都会说: rownum一定要包括1.
ahujyy 2008-07-28
  • 打赏
  • 举报
回复
谢谢各位的讲解.特别感谢lxxzhy.结帖了.
胡矣 2008-07-27
  • 打赏
  • 举报
回复
请问
select rownum no,id,name from student where rownum <=3 and rownum >=2
能行吗?
一个道理啊
wangydong 2008-07-27
  • 打赏
  • 举报
回复
当然不行了,select * from (select rownum no,id,name from student where rownum <=3 ) where no >=2;是高等内层查完了才查外层,而后者是并列的。
内容概要:本文研究油浸式变压器在不同气候条件下的能量极限问题,通过Matlab代码实现建模与仿真,深入分析环境温度、湿度等气候因素对变压器热稳定性、负载能力及运行安全性的影响,进而确定其在多种工况下的最大能量承载极限。研究采用多智能体方法提升模型的适应性与仿真精度,综合考虑热平衡方程与环境参数输入,旨在为变压器的设计优化、容量规划、动态负载管理及智能电网中的可靠性分析提供科学依据和技术支撑。; 适合人群:具备电力系统基础知识和Matlab编程能力,从事电气工程、能源系统仿真、电力设备设计等相关领域的科研人员与工程师,特别适合研究生及工作1-5年的专业技术人才; 使用场景及目标:①评估油浸式变压器在极端气候环境下的安全运行边界;②优化变压器的负载调度与能效管理策略;③支持智能电网背景下设备级动态容量规划与韧性电网建设;④为高可靠性供电系统的设计与运维提供理论参考; 阅读建议:学习者应结合提供的Matlab代码深入理解建模流程,重点掌握热传导模型构建、环境变量设定、多智能体协同机制及仿真参数调优方法,并通过调整气候条件进行多场景仿真实验,以深化对变压器能量极限形成机理的认知。
内容概要:本文系统研究了基于开关电容器的级联多电平逆变器在布尔PWM控制技术下的工作特性与仿真实现,深入分析该拓扑结构的工作原理、电容电压自平衡能力及其对输出波形质量的优化作用。通过Simulink平台构建完整的系统仿真模型,验证布尔PWM控制策略在抑制谐波畸变、提升直流电压利用率和改善输出电压精度方面的有效性,进一步探讨其在高效率、高电能质量要求的电力电子变换系统中的应用潜力,为新型多电平逆变器的设计与控制提供理论依据与技术支撑。; 适合人群:电气工程、自动化、电力电子与电力传动等相关专业的高校本科生、研究生,从事新能源发电、电机驱动及电力系统仿真的科研人员,以及具备MATLAB/Simulink基础并希望深入理解先进PWM控制技术的工程技术人员。; 使用场景及目标:①掌握开关电容器型级联多电平逆变器的结构优势与运行机理;②理解布尔PWM控制的基本原理及其在多电平调制中的独特优势;③通过Simulink仿真实践,掌握控制模型搭建、参数整定与仿真结果分析方法;④为开展高性能逆变器相关课题研究或实际工程项目提供可复现的技术参考与设计思路。; 阅读建议:建议读者结合Simulink模型进行同步操作,重点关注布尔逻辑调制信号的生成方式、开关器件的驱动时序设计及电容电压动态响应特性,对比传统载波PWM等调制方法的性能差异,深入理解控制策略对系统稳态与动态性能的影响。同时可进一步拓展学习空间矢量PWM(SVPWM)、最近电平逼近(NLC)等其他先进调制技术,以全面掌握多电平逆变器的控制体系。

62,623

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧