针对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修改过
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .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程序,适合新人练手)