繁体中文
设为首页
加入收藏
当前位置:技术首页 >> 数据库 >> Sql server >> SQL 2005的ROW_NUMBER()实现分页功能

SQL 2005的ROW_NUMBER()实现分页功能

2007-05-08 15:07:21  作者:  来源:赛迪网  浏览次数:255  文字大小:【】【】【
简介: DECLARE @pagenum AS INT, @pagesize AS INT SET @pagenum = 2 SET @pagesize = 3 SELECT * FROM (SELECT ROW_NUMBER() OVER(ORDER BY newsid DESC) AS rownum, newsid, topic, ntim ...
关键字:SQL 2005


DECLARE @pagenum AS INT, @pagesize AS INT
SET @pagenum = 2
SET @pagesize = 3
SELECT *
FROM (SELECT ROW_NUMBER() OVER(ORDER BY newsid DESC) AS rownum, 
        newsid, topic, ntime, hits
      FROM news) AS D
WHERE rownum BETWEEN (@pagenum-1)*@pagesize+1 AND @pagenum*@pagesize
ORDER BY newsid DESC

aspx里面只需给SQL传入pageid和条数即可。

CSDN上还有个存储过程实现分页的代码:

ALTER PROCEDURE news_Showlist
(
@tblName   varchar(255),       -- 表名
@strGetFields varchar(1000),  -- 需要返回的列
@fldName varchar(255),      -- 排序的字段名
@PageSize   int ,          -- 页尺寸
@PageIndex  int ,           -- 页码
@strWhere  varchar(1500),  -- 查询条件(注意: 不要加where)
@Sort varchar(255)      --排序的方法

)
AS
declare @strSQL   varchar(5000)       -- 主语句
declare @strTmp   varchar(110)        -- 临时变量
declare @strOrder varchar(400)        -- 排序类型

if @Sort = 'desc'
begin
set @strTmp = '<(select min'
set @strOrder = ' order by ' + @fldName +' desc'
--如果@OrderType不是,就执行降序,这句很重要!
end
else
begin
set @strTmp = '>(select max'
set @strOrder = ' order by ' + @fldName +' asc'
end
 
if @PageIndex = 1
begin
if @strWhere != ''   
  begin
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ' + @tblName 
+ ' where ' + @strWhere + ' ' + @strOrder
  end
else
  begin
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from '+ @tblName 
+ ' '+ @strOrder
  end
--如果是第一页就执行以上代码,这样会加快执行速度
end
else
begin
--以下代码赋予了@strSQL以真正执行的SQL代码
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from '
+ @tblName + ' where ' + @fldName + '' + @strTmp + '('+ @fldName + ') from 
(select top ' + str((@PageIndex-1)*@PageSize) + ' '+ @fldName + ' from ' 
+ @tblName + '' + @strOrder + ') as tblTmp)'+ @strOrder
 
if @strWhere != ''
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from '
+ @tblName + ' where ' + @fldName + '' + @strTmp + '('+ @fldName + ') from 
(select top ' + str((@PageIndex-1)*@PageSize) + ' '+ @fldName + ' from '
 + @tblName + ' where ' + @strWhere + ' '+ @strOrder + ') as tblTmp) 
and ' + @strWhere + ' ' + @strOrder
end
exec (@strSQL)
RETURN

点击收藏到

责任编辑:admin

本文引用地址: http://tech.itzero.com/2007/0508/16553.html 请粘贴到你的QQ/MSN上推荐给你的好友

相关文章
SQL 2005的SSIS与Oracle的迁移性能
SQL 2005 XML 最佳实施策略目录视图
SQL Server 2005数据加密技术应用研究
SQL Server 2005 存储过程写报表举例
SQL Server 2005 XML最佳实施策略用法
SQL Server 2005的XML支持与异常处理
SQL Server 2005报表服务不能启动问题
SQL Server 2005密码安全追踪与存储
SQL Server 2005手工卸载命令
SQL Server 2005中各个系统表的作用
 

最新文章

更多

· SQL Server 数据库操作实...
· 启动SQL Server时自动执...
· 一个回滚段损坏的修复实例
· 教你如何来恢复一个丢失...
· SQL 2005的SSIS与Oracle...
· SQL 2005 XML 最佳实施策...
· SQL 2005的ROW_NUMBER()...
· SQL2005中异常处理消息框...
· SQL Server 2005数据加密...
· SQL Server 2005 存储过...

热点文章

更多

其它推荐