今天要分页,要用到ROW_NUMBER(),在网上找了一些关于ROW_NUMBER()用法的资料,

结果都没有说到了要点,浪费了好多时间!

下面以我的个人体会讲讲ROW_NUMBER()的用法,

 

代码
ALTER PROCEDURE dbo.Flash_SearchSinger 
(
   
@pageindex      int,          //页数;
   
@pagesize       int,          //每页的记录的条数
   
@singername     nvarchar(30)  //我做的是一个搜索页面,这是参数

AS
 
begin 
    
with singer AS(    //注意:这里的singer不是表名,而是你自己随便取的一个临时表名!!!我就在这花了1个多小时!
    
SELECT ROW_NUMBER() OVER(ORDER BY AddTime DESC)ROW,ID,SingerName,PhotoAddress FROM SingerList where singername like '%'+@singername+'%')
   
    
SELECT SingerName AS'歌手姓名' ,PhotoAddress AS'图片地址',ID AS'singerid' FROM Singer //注意:这里查询的是我们刚刚用的临时表名,而不是数据库里的表名    
    
Where ROW BETWEEN @pageindex*@pagesize AND @pageindex*@pagesize+@pagesize-1           //分页的页面
end 

 


这就是ROW_NUMBER()的用法!

用法的效率很不错!

节省了原来SQL 2000里的好多代码!

小弟学艺不精,欢迎大家拍砖指正....
 
posted on 2010-01-27 16:11  钱途无梁  阅读(431)  评论(0编辑  收藏  举报