SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程(支持单表或多表结查集分页)
2015-06-02 15:46
756 查看
原文:SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程(支持单表或多表结查集分页)SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程,支持单表或多表结查集分页,存储过程如下:
用法如下:
结果显示如下(如上多表查询):
/******************/ --Author:梦在旅途(www.Zuowenjun.cn) --CreateDate:2015-06-02 --Function:分页获取数据 /******************/ create procedure [dbo].[sp_DataPaging] ( @selectsql nvarchar(200),--查询字段SQL,不含select,支持灵活写法,如:col1,col3,isnull(col4,'') as col4 @fromsql nvarchar(500),--查询表及条件SQL,不含from,若包含条件请加上where,如:table where col1='test' @orderbysql nvarchar(100),--查询排序SQL,不含order by,如:id order by desc @pagesize int=20,--每页显示记录数 @pageno int=1,--当前查询页码,从1开始 @returnrecordcount bit=1 --是否需要返回总记录数,若设为1,则返回两个结果表 ) as begin declare @sqlcount nvarchar(500),@sqlstring nvarchar(max) set @sqlstring=N'from (select row_number() over (order by ' + @orderbysql + N') as rowId,' + @selectsql + N' from ' + @fromsql +N') as t' if(@returnrecordcount=1) begin set @sqlcount=N'select count(rowId) as resultcount ' + @sqlstring exec(@sqlcount) end set @sqlstring=N'select * ' + @sqlstring + ' where rowId between ' + convert(nvarchar(50),(@pageno-1)*@pagesize+1)+' and '+convert(nvarchar(50),@pageno*@pagesize) exec(@sqlstring) end
用法如下:
--单表查询 exec [dbo].[sp_DataPaging] '*','AssetDetail','assetsingleno',10,1 --多表查询 exec [dbo].[sp_DataPaging] 'a.*','Inventory a left join AssetDetail b on a.StoreNo=b.StoreNo and a.CompanyID=b.CompanyID inner join Asset c on b.AssetID=c.ID and b.CompanyID=c.CompanyID','a.id',20,3,1
结果显示如下(如上多表查询):
相关文章推荐
- 【RAC】rac环境下的数据库备份与还原
- Mysql 中view创建
- 安装oracle(版本:11G)
- mysql 5.6 升级5.7
- LinQ to SQL
- 把excel数据生成sql insert语句
- MySQL utf8mb4 字符集
- 把excel数据生成sql insert语句
- [SQLite3]connection string的连接池参数引发的错误
- MongoDB学习笔记~自己封装的Curd操作(按需更新的先决条件)
- windows下安装mongodb
- mysql主从不一致解决方法
- 一些oracle知识
- rlwrap-0.37.tar.gz实现sqlplus上下翻页
- 在oracle中,使用sqlldr将文件中的数据导入到数据库
- 删除全部binlog不影响数据库运行,类似Oracle的archivelog
- mysql 的 infobright 数据库的 mediumblob 显示不了数据
- Mac下MySql卸载方法
- mysql清理binlog
- SQLServer中的事务与锁