存储过程分页

--[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

 

posted @   wolfsocket  阅读(56)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示