ROW_NUMBER()用法

本文介绍使用 SQL Server 中的 ROW_NUMBER() 函数实现高效分页的方法。通过具体实例展示了如何创建存储过程来搜索歌手信息,并进行分页显示。文章强调了正确使用临时表名的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

 1ALTER PROCEDURE dbo.Flash_SearchSinger 
 2  @pageindex int,   //页数;
 3  @pagesize int,    //每页的记录的条数
 4  @singername nvarchar(30)   //我做的是一个搜索页面,这是参数
 5AS
 6begin 
 7with singer AS(    //注意:这里的singer不是表名,而是你自己谁便取的一个临时表名!!!我就在这花了1个多小时!
 8SELECT ROW_NUMBER() OVER(ORDER BY AddTime DESC)ROW,ID,SingerName,PhotoAddress FROM SingerList where singername like '%'+@singername+'%')
 9  
10SELECT SingerName AS'歌手姓名' ,PhotoAddress AS'图片地址',ID AS'singerid' FROM Singer //注意:这里查询的是我们刚刚用的临时表名,而不
11                                                                                                 //是数据库里的表名    
12Where ROW BETWEEN @pageindex*@pagesize AND @pageindex*@pagesize+@pagesize-1         //分页的页面
13end 

这就是ROW_NUMBER()的用法!

用法的效率很不错!

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

转载于:https://www.cnblogs.com/fly871117/archive/2008/08/14/1267476.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值