针对Ext js的分页存储过程-适用于sqlserver2008

复制代码
USE [UTMP_RC_121213]
GO
/****** Object:  StoredProcedure [dbo].[PageProc]    Script Date: 01/05/2013 08:45:56 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:        刘晓伦
-- Create date: 12-10-13
-- Description:    分页存储过程,
-- 如果使用ExcuteReader()方法执行此存储过程
-- 必须先reader.close()才能得到输出参数
-- =============================================
ALTER PROCEDURE [dbo].[PageProc]
( 
@sqlStr     nvarchar(max),    ----SQL语句 
@startRow   int,        ----开始的行
@pageSize   int,        ----一页多少行
@orderBy    nvarchar(max),    ----排序条件 
@rowCount    int = 1 output  ----一共多少行
) AS
BEGIN
SET NOCOUNT ON;
Declare @sql nvarchar(max)
Declare @csql nvarchar(max)
--todo:此处为了方便使用,没有考虑性能,意图是得到一共有多少行
select @csql = 'select @Counts = count(*) from ('+@sqlStr+') as t'
select @sql = 'select * from (select ROW_NUMBER() OVER (#order_by_replace_holder#)  AS RINDEX ,* FROM ( '+@sqlStr+' ) as t ) as b where '+ CAST(@startRow+1 as varchar)+' <= RINDEX and RINDEX <= '+CAST(@startRow+@pageSize as varchar)
select @sql = REPLACE(@sql,'#order_by_replace_holder#',@orderBy)
--把一共有多少行记录写入输出参数
exec sp_executesql @csql,N'@Counts int out ',@rowCount out 
--获得检索结果
exec sp_executesql @sql
    
END
复制代码

在2013-1-5修改过

posted @   liulun  阅读(1008)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
历史上的今天:
2009-10-15 俄罗斯方块源代码(winform程序,适合新人练手)
点击右上角即可分享
微信分享提示