当前位置: 首页 > news >正文

Java如何查行数_如何正确利用Rownum来限制查询所返回的行数?

看到一篇好文章,大家一起看看

[转贴]如何正确利用Rownum来限制查询所返回的行数?

软件环境:

1、Windows NT4.0+ORACLE 8.0.4

2、ORACLE安装路径为:C:\ORANT

含义解释:

1、rownum是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,

依此类推,这个伪字段可以用于限制查询返回的总行数。

2、rownum不能以任何基表的名称作为前缀。

使用方法:

现有一个商品销售表sale,表结构为:

month    char(6)      --月份

sell    number(10,2)   --月销售金额

create table sale (month char(6),sell number);

insert into sale values('200001',1000);

insert into sale values('200002',1100);

insert into sale values('200003',1200);

insert into sale values('200004',1300);

insert into sale values('200005',1400);

insert into sale values('200006',1500);

insert into sale values('200007',1600);

insert into sale values('200101',1100);

insert into sale values('200202',1200);

insert into sale values('200301',1300);

insert into sale values('200008',1000);

commit;

SQL> select rownum,month,sell from sale where rownum=1;(可以用在限制返回记录条数的地方,保证不出错,如:隐式游标)

ROWNUM MONTH SELL

--------- ------ ---------

1 200001 1000

SQL> select rownum,month,sell from sale where rownum=2;(1以上都查不到记录)

没有查到记录

SQL> select rownum,month,sell from sale where rownum>5;

(由于rownum是一个总是从1开始的伪列,Oracle 认为这种条件不成立,查不到记录)

没有查到记录

只返回前3条纪录

SQL> select rownum,month,sell from sale where rownum<4;

ROWNUM MONTH SELL

--------- ------ ---------

1 200001 1000

2 200002 1100

3 200003 1200

如何用rownum实现大于、小于逻辑?(返回rownum在4—10之间的数据)(minus操作,速度会受影响)

SQL> select rownum,month,sell from sale where rownum<10

2 minus

3 select rownum,month,sell from sale where rownum<5;

ROWNUM MONTH SELL

--------- ------ ---------

5 200005 1400

6 200006 1500

7 200007 1600

8 200101 1100

9 200202 1200

想按日期排序,并且用rownum标出正确序号(有小到大)

SQL> select rownum,month,sell from sale order by month;

ROWNUM MONTH SELL

--------- ------ ---------

1 200001 1000

2 200002 1100

3 200003 1200

4 200004 1300

5 200005 1400

6 200006 1500

7 200007 1600

11 200008 1000

8 200101 1100

9 200202 1200

10 200301 1300

查询到11记录.

可以发现,rownum并没有实现我们的意图,系统是按照记录入库时的顺序给记录排的号,rowid也是顺序分配的

SQL> select rowid,rownum,month,sell from sale order by rowid;

ROWID ROWNUM MONTH SELL

------------------ --------- ------ ---------

000000E4.0000.0002 1 200001 1000

000000E4.0001.0002 2 200002 1100

000000E4.0002.0002 3 200003 1200

000000E4.0003.0002 4 200004 1300

000000E4.0004.0002 5 200005 1400

000000E4.0005.0002 6 200006 1500

000000E4.0006.0002 7 200007 1600

000000E4.0007.0002 8 200101 1100

000000E4.0008.0002 9 200202 1200

000000E4.0009.0002 10 200301 1300

000000E4.000A.0002 11 200008 1000

查询到11记录.

正确用法,使用子查询

SQL> select rownum,month,sell from (select month,sell from sale group by month,sell) where rownum<13;

ROWNUM MONTH SELL

--------- ------ ---------

1 200001 1000

2 200002 1100

3 200003 1200

4 200004 1300

5 200005 1400

6 200006 1500

7 200007 1600

8 200008 1000

9 200101 1100

10 200202 1200

11 200301 1300

按销售金额排序,并且用rownum标出正确序号(有小到大)

SQL> select rownum,month,sell from (select sell,month from sale group by sell,month) where rownum<13;

ROWNUM MONTH SELL

--------- ------ ---------

1 200001 1000

2 200008 1000

3 200002 1100

4 200101 1100

5 200003 1200

6 200202 1200

7 200004 1300

8 200301 1300

9 200005 1400

10 200006 1500

11 200007 1600

查询到11记录.

利用以上方法,如在打印报表时,想在查出的数据中自动加上行号,就可以利用rownum。

返回第5—9条纪录,按月份排序

SQL> select * from (select rownum row_id ,month,sell

2 from (select month,sell from sale group by month,sell))

3 where row_id between 5 and 9;

ROW_ID MONTH SELL

---------- ------ ----------

5 200005 1400

6 200006 1500

7 200007 1600

8 200008 1000

9 200101 1100

相关文章:

  • java 3 4_3-4 Java基础第四天
  • php phar 文件使用,PHP如何操作phar文件
  • java使用xpath解析xml,java使用XPath解析xml
  • php脚本防护,PHP的一个EVAL的利用防范
  • php中背景图怎么设置不重复,css怎么让背景图片不重复
  • java标签更改显示,离子选项卡,如何在标签更改上显示微调器?
  • java读写二进制文件 移动指针 seek,《Java大学教程》—第20章 文件处理
  • php权限无需验证的控制器,控制器 · ThinkPHP5权限管理 · 看云
  • 两'参数粒子群matlab,SVM用粒子群优化参数
  • 数据在文本框中显示 php,在文本框中使用php和纯ajax从数据库加载数据
  • 数字信号处理matlab滤波器,数字信号处理matlab滤波器课程设计
  • matlab逆求贝塞尔函数变量值,MATLAB怎么求解有贝塞尔函数的问题,求高手帮帮忙,谢谢...
  • java 继承 默认作用域,Spring(三)——Bean的 继承关系、依赖关系、作用域
  • matlab中的newfis,(To be removed) Create new fuzzy inference system
  • php apache 301重定向,Apache下修改.htaccess实现301重定向方法汇总
  • [ JavaScript ] 数据结构与算法 —— 链表
  • [deviceone开发]-do_Webview的基本示例
  • Computed property XXX was assigned to but it has no setter
  • Docker入门(二) - Dockerfile
  • DOM的那些事
  • express如何解决request entity too large问题
  • Java新版本的开发已正式进入轨道,版本号18.3
  • Laravel 菜鸟晋级之路
  • ng6--错误信息小结(持续更新)
  • python_bomb----数据类型总结
  • Sequelize 中文文档 v4 - Getting started - 入门
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • Tornado学习笔记(1)
  • V4L2视频输入框架概述
  • windows-nginx-https-本地配置
  • - 概述 - 《设计模式(极简c++版)》
  • 十年未变!安全,谁之责?(下)
  • 原生 js 实现移动端 Touch 滑动反弹
  • 国内开源镜像站点
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • #1014 : Trie树
  • #我与Java虚拟机的故事#连载08:书读百遍其义自见
  • #我与Java虚拟机的故事#连载12:一本书带我深入Java领域
  • (BFS)hdoj2377-Bus Pass
  • (zhuan) 一些RL的文献(及笔记)
  • (顶刊)一个基于分类代理模型的超多目标优化算法
  • (多级缓存)多级缓存
  • (二)springcloud实战之config配置中心
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (转)socket Aio demo
  • ***php进行支付宝开发中return_url和notify_url的区别分析
  • . Flume面试题
  • .java 指数平滑_转载:二次指数平滑法求预测值的Java代码
  • .naturalWidth 和naturalHeight属性,
  • .NET Core跨平台微服务学习资源
  • .NET 使用 XPath 来读写 XML 文件
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • @DateTimeFormat 和 @JsonFormat 注解详解