ROW_NUMBER()的用法__(个人经验)

今天要分页,要用到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里的好多代码!

小弟学艺不精,欢迎大家拍砖指正....
 

你可能感兴趣的:(row_number())