分页SQL语句
CREATE PROC [dbo].[Procpageselect] @table NVARCHAR(max),-- 输入参数,表名
@columns NVARCHAR(max),-- 输入参数,要返回的列
@rows INT,-- 输入参数,每页显示的数据量
@page INT,-- 输入参数,当前页面
@orderBy NVARCHAR(max),-- 输入参数,数据按什么字段排序,后面加上desc表示倒序
@condition NVARCHAR(max),-- 输入参数,sql形式的筛选查询条件
@total INT output -- 输出参数,满足上诉查询条件的数据总数
AS
BEGIN
DECLARE @start INT -- 变量,获取的当页数据的起始位置
DECLARE @end INT -- 变量,获取的当页数据的结束位置
DECLARE @sql NVARCHAR(max) -- 变量,保存动态生成的sql语句
IF @condition = ''
OR @condition IS NULL
BEGIN
SET @condition = '1=1'
END
SET @sql = 'select @count = COUNT(*) from ' + @table
+ ' where ' + @condition
EXEC Sp_executesql
@sql,
N'@count int output',
@total output
--print(@total)
SET @start = @rows * ( @page - 1 )
SET @end = @rows * @page
SET @sql = 'with tmp as (select ROW_NUMBER() over(order by '
+ @orderBy + ') as [no], ' + @columns
+ ' from (select * from ' + @table + ' where '
+ @condition
+ ') as a) select * from tmp where [no] > '
+ Ltrim(Str(@start)) + ' and [no] <= '
+ Ltrim(Str(@end))
--print(@sql)
EXEC(@sql)
END
个人主要研究:金融系统、MIS系统、人力资源管理系统、数据采集系统、权限管理系统等等系统。主攻C#开发语言,Oracle、Sql Server,WCF和Remoting通信。
如需联系可加QQ:442389681 Email:lxc880615@163.com 手机:18922735098
QQ群交流:186841119 (请注明来自博客园)
博客园地址:http://www.cnblogs.com/jara/ http://www.cnblogs.com/luoyuhao/
提示:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如果觉得还有帮助的话,可以点一下右下角的【推荐】,希望能够持续的为大家带来好的技术文章!想跟我一起进步么?那就【关注】我吧。
如果对文章有任何问题,都可以在评论中留言,我会尽可能的答复您,谢谢您的阅读

浙公网安备 33010602011771号