rownum伪行号-排行榜-分页

1.rownum 是oracle数据库特有的一个特性,它针对每一个查询(包括子查询),都会生成一个rownum用于对该次查询进行编号

2.每个rownum只针对当前select 查询有效,可以使用别名进行显示

例子:select rownum,emp.* from emp; --表名指定列(* 前面一定要别名指定列,或者表名指定列)

例子:查询出工资最高的前五名

--6个字句的执行先后 :from ,where,group by ,having,select ,select

--先排序,后筛选

(错误)select rownum,emp.* from emp where rownum<=5 order by sal desc; --先筛选后排序

select * from (select * from emp order by sal desc) where rownum<=5; --要先排序,后筛选

排行榜
例子:

--查询出工资水平在前5名的员工姓名,和工资

--理解:先排序,在通过rownum查询出前5条,在查看工资是否存在在这前5条里面

--本例包含三个查询,共有三个rownum

select ename ,sal from emp

where sal in(select * from ( select sal from emp order by sal desc) where rownum<=5) and rownum<=5;

例子:

--查询出工资最低的前五名

--注意:查询排行榜时,可能遇到边界问题

select rownum,emp.* from emp where rownum<=5 order by sal;

--查询出工资最低的前五名 的姓名和工资

select ename,sal from emp

where sal in (select * from (select sal from emp order by sal asc ) where rownum <=5) and rownum <=5;

分页查询
--分页计算参数:第几页,分页大小 --计算分页

--两种分页方法:rownum 和rownumde 别名

注意:rownum 不支持 > 和 >= 判断;rownum的别名支持>和>=判断

方法一

例子:

分页查询员工姓名,工资,入职日期;每页显示5条 分别查询出第1,2,3页数据

方法一:

理解:先在子查询中查询出前N页,在二次主查询查询出第N页;需要在子查询rownum别名

--首先用子查询查询出1*5 1-5页,再用主查询查询出大于(1-1)*5 >0 1-2-3-4-5 就是第1页

--首先用子查询查询出2*5 1-10页,再用主查询查询出大于(2-1)*5 >5 6-7-8-9-10就是第2页

--首先用子查询查询出3*5 1-15页,再用主查询查询出大于(3-1)*5 >5 11-12-13-14-15就是第3页

select * from (select rownum rn,emp.* from emp where rownum <=1*5) where rn >(1-1)*5

select * from (select rownum rn,emp.* from emp where rownum <=2*5) where rn >(2-1)*5

select * from (select rownum rn,emp.* from emp where rownum <=3*5) where rn >(3-1)*5

方法二:

--先在子查询中查询出所有的数据和数据的rownum,并使用别名表示,在第二次主查询中通过别名进行分页控制

理解:--首先用子查询查询出所有数据 ,在用主查询控制分页:(3-1)*5<=rn<=3*5 第3页

--首先用子查询查询出所有数据 ,在用主查询控制分页:(2-1)*5<=rn<=2*5 第2页

--首先用子查询查询出所有数据 ,在用主查询控制分页:(1-1)*5<=rn<=1*5 第1页

select * from (select rownum rn,emp.* from emp ) where rn<=3*5 and rn>=(3-1)*5;

select * from (select rownum rn,emp.* from emp ) where rn<=2*5 and rn>=(2-1)*5;

select * from (select rownum rn,emp.* from emp) where rn<=1*5 and rn>=(1-1)*5;

方法一的效率更高

rownum伪行号-排行榜-分页的更多相关文章

  1. oracle 行号和分页

    1.行号是个伪列,rownum 永远按照默认的顺序生成 2.rownum 只能使用< <= 不能使用>  >=(原因是oracle数据库是行式数据库,像盖楼一样,没有第一层就排 ...

  2. EasyPOI校验实现返回错误信息及行号

    IExcelModel 获取错误信息 public class ExcelVerifyEntity implements IExcelModel { private String errorMsg; ...

  3. css伪类实现行号自动填充

    css伪类实现行号自动填充 大多数时候我们需要行号自动填充的时候我们可以 大多数时候是插入元素, 在元素里用js填入行号,或者用 ol > li 实现行号填充, 对于上面的方式,都不太灵活,而且 ...

  4. MySQL查询获取行号rownum

    MySQL中可以使用变量产生行号,下面是2个简单例子: 使用工具:MySQL Workbench 说明:表heyf_10中字段,empid(员工工号).deptid(部门编号).salary(薪资): ...

  5. DOJO-dojox.grid.EnhancedGrid(带刷新函数,分页工具栏,复选框,行号等功能)

    转自:http://biancheng.dnbcw.info/javascript/395865.html dojo.require("dojox.grid.EnhancedGrid&quo ...

  6. Sqlite中使用rowid来表示行号,用于分页。

    在SQLite的查询结果中显示行号,可以使用select rowid as RowNumber ,* from WSCLanguage: select rowid as RowNumber ,* fr ...

  7. SQL基础--ROWNUM伪列

    ROWNUM伪列 的概念: rownum表示的是一个数据行编号的伪列,它的内容是在用户查询数据时,为用户动态分配的一个数组(行号). 注意它是随机生成的,并不是和某一行数据绑定在一起的. 观察rown ...

  8. sql使用row_number()查询标记行号

    背景: 在分页功能中,记录需分页显示,需要row_number()函数标记行号. 数据表: 排序之前数据表显示: sql语句: select ROW_NUMBER() over(order by id ...

  9. Oracle中ROWNUM伪列和ROWID伪列的用法与区别

    做过Oracle分页的人都知道由于Oracle中没有像MySql中limit函数以及SQLServer中的top关键字等,所以只能通过伪列的方式去满足分页功能,在此,不谈分页方法,只从根本上去介绍这两 ...

随机推荐

  1. Domain Socket本地进程间通信

    socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络socket也可用于同一台主机的进程间通讯(通过loop ...

  2. 【luogu4145】上帝造题的七分钟2 / 花神游历各国--区间开根-线段树

    题目背景 XLk觉得<上帝造题的七分钟>不太过瘾,于是有了第二部. 题目描述 "第一分钟,X说,要有数列,于是便给定了一个正整数数列. 第二分钟,L说,要能修改,于是便有了对一段 ...

  3. 《视觉SLAM十四讲》学习日志(二)——初识SLAM

    小萝卜机器人的例子: 就像这种机器人,它的下面有一组轮子,脑袋上有相机(眼睛),为了让它能够探索一个房间,它需要知道: 1.我在哪——定位 2.周围环境怎么样——建图 定位和建图可以理解成感知的 &q ...

  4. 使用Ajax向SpringMVC传递Json数据

    这篇文章已经过时了. 请参考比较合适的前后端交互方式. 1.保证SpringMVC配置成功了. 2.在pom.xml中追加Jackson相关的依赖 <dependency> <gro ...

  5. python 小游戏 “外星飞船入侵”

    Project Title 项目名称 “外星飞船入侵”, git地址:https://github.com/lilinyu861/Alien-Invasion 效果图: 参考: https://blo ...

  6. java试题复盘——9月26日

    5.在 JAVA 编程中, Java 编译器会将 Java 程序转换为(A) A.  字节码 B.  可执行代码 C.  机器代码 D.  以上都不对 解析: 编译器将Java源代码编译成字节码cla ...

  7. AE开发之shp转txt

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  8. Selenium处理页面懒加载方法

    在做selenium webdriver  在做UI自动化时,有些页面时使用懒加载的形式显示页面图片,如果在不向下移动滚动条时,获取到的图片会是网站的默认图片和真实的图片不相符. 1.滑动滚动条 1. ...

  9. @Transactional注解详细用法

    概述 事务管理对于企业应用来说是至关重要的,即使出现异常情况,它也可以保证数据的一致性.Spring Framework对事务管理提供了一致的抽象,其特点如下: 为不同的事务API提供一致的编程模型, ...

  10. 去除IntelliJ IDEA对重复代码的检测

    方法1:  方法2:(比较简便)