存储过程分页
--[usp_tb_Sort] 10,2,'createdate desc',' select * FROM tb_ItemInspection'
create PROC [dbo].[usp_tb_Sort]
@PageSize Int = 0 --一页显示条数
,@CurrentPageIndex Int = 0 ---显示的页数
,@SortExpression nvarchar(100) ='' ---排序条件
,@SQL VARCHAR(max) --传递过来的SQL语句
AS
CREATE TABLE #RecordCount
(
RecordCount VARCHAR(50)
)
BEGIN
DECLARE @TempSql varchar(MAX) --临时存放sql语句
DECLARE @ListSql varchar(MAX) --临时存放sql语句
DECLARE @RecordCount VARCHAR(50)
set @TempSql='SELECT COUNT(1) FROM ('+@SQL+') t'
insert into #RecordCount EXEC (@TempSql)
SET @RecordCount= (SELECT RecordCount FROM #RecordCount)
Declare @StartRow VARCHAR(50)
Declare @EndRow VARCHAR(50)
Set @StartRow = (@CurrentPageIndex-1)*@PageSize+1
Set @EndRow = @CurrentPageIndex*@PageSize
IF(@CurrentPageIndex>1 AND @StartRow>@RecordCount)
BEGIN
SET @CurrentPageIndex=@CurrentPageIndex-1
SET @StartRow = (@CurrentPageIndex-1)*@PageSize+1
SET @EndRow = @CurrentPageIndex*@PageSize
END
SELECT RecordCount FROM #RecordCount
set @ListSql ='SELECT
*
FROM
(
SELECT
ROW_NUMBER () OVER (
Order By '+ @SortExpression + '
) AS RowNum
,*
FROM ('+ @SQL+') t
) AS RECORDS
WHERE RowNum BETWEEN '+ @StartRow +'AND '+@EndRow
EXEC(@ListSql)
END
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现