浅淡sqlserver的top与oracle的rownum

浅淡sqlserver的top与oracle的rownum

ID:34779698

大小:178.18 KB

页数:5页

时间:2019-03-10

浅淡sqlserver的top与oracle的rownum_第1页
浅淡sqlserver的top与oracle的rownum_第2页
浅淡sqlserver的top与oracle的rownum_第3页
浅淡sqlserver的top与oracle的rownum_第4页
浅淡sqlserver的top与oracle的rownum_第5页
资源描述:

《浅淡sqlserver的top与oracle的rownum》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、平时的项目开发中,分页存储过程是用的比较多的存储过程,SqlServer分页存储过程中经常要用到top,Oracle中则经常用到了RowNum.      现在,有一个UserInfo表,一个字段是UserId,另一个字段是UserName,其中是UserId是自动增长的,步长是1.表中共有30条数据,其中UserId的值不一定是连续的。现在要实现的目的是取其中的第11至第20条记录。先看SqlServer的几种做法:    第一种写法:select top 10 *   from UserInfo   where UserId in   

2、     (        select top 20 UserId         from UserInfo       )  order by UserId desc      第二种写法: select top 10 * from UserInfo where UserId not in   (selecttop10 UserId from UserInfo )      第三种写法: select top 10 * from UserInfo where UserId> (select max(UserId) from    (s

3、electtop10 UserId from UserInfo orderby UserId) a)     第四种写法(只可在Sqlserver2005中):select * from (select Row_Number() over     (Orderby UserId) as RowId ,*from UserInfo) U where U.RowId between10and20     Sqlserver中其实还有另外几种写法,不一一写出。四种方法中,后两种的写法要比前两种写法效率要高些,但第四种只能写在SqlServer20

4、05中。  在看Oracle中实现取其中的第11至第20条记录的做法之前,先看看一些人在使用RowNum遇到的莫名其妙的怪事。表同样是UserInfo,30条数据select t.*from userinfo t where rownum>10   查询结果:     理论上应该是有20条数据才对啊,问题出现在哪呢?  因为ROWNUM是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列(这里要强调的一点是:先要有结果集)。简单的说rownum是对符合条件结果的序列号。所以对于rownum>10没有数据是否可以这样理解:  ROWNU

5、M是一个序列,是oracle数据库从数据文件或缓冲区中读取数据的顺序。它取得第一条记录则rownum值为1,第二条为2,依次类推。如果你用>,>=,=,between...and这些条件,因为从缓冲区或数据文件中得到的第一条记录的rownum为1,则被删除,接着取下条,可是它的rownum还是1,又被删除,依次类推,最后的查询结果为空。  再看下面一条sql语句:select t.* from userinfo t where rownum!=10   查询结果:    查出的来结果不是21条,而是9条。可以这样理解:rownum为9后的记

6、录的rownum为10,因条件为!=10,所以去掉,其后记录补上,rownum又是10,也去掉,一直这样下去,最后的结果只有9条了。  如果把后面的条件改为whererownum>1时,会发现查不到一条数据,如果是whererownum>0或是whererownum>=1时则可以查询到所有的数据。原因很简单:因为rownum是在查询到的结果集后加上去的,它总是从1开始。   between1and20或者between0and20能查到结果,而用between2and20却得不到结果,原因同上一样,因为rownum总是从1开始。   所以要

7、实现取UserInfo表其中的第11至第20条记录,可以这样写:select *  from (select rownum as rn,t.* from userinfo t where rownum >0)where rn between 10 and 20查询结果:    当然也可以这样写: select   *   from   UserInfo   where   rownum<20        minus       select   *   from   UserInfo   where   rownum<10这种写法没有前面

8、那种效率高。 但不能这样写:select t.* from UserInfo t where rownum between 10 and 20select t.* from Us

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。