首页 > 数据库技术 > 详细

.net SQLSERVER 分页存储过程

时间:2018-06-20 12:09:09      阅读:201      评论:0      收藏:0      [点我收藏+]

create PROCEDURE [dbo].[proc_SplitPage]
@tblName varchar(255), -- 表名
@strFields varchar(1000) = ‘*‘, -- 需要返回的列,默认*
@strOrder varchar(255)=‘‘, -- 排序的字段名,必填
@strOrderType varchar(10)=‘ASC‘, -- 排序的方式,默认ASC
@PageSize int = 10, -- 页尺寸,默认10
@PageIndex int = 1, -- 页码,默认1
@strWhere varchar(1500) = ‘‘ -- 查询条件 (注意: 不要加 where)
AS

declare @strSQL varchar(5000)

if @strWhere !=‘‘
set @strWhere=‘ where ‘+@strWhere

set @strSQL=
‘SELECT * FROM (‘+
‘SELECT ROW_NUMBER() OVER (ORDER BY ‘+@strOrder+‘ ‘+@strOrderType+‘) AS pos,‘+@strFields+‘ ‘+
‘FROM ‘+@tblName+‘ ‘+@strWhere+
‘) AS sp WHERE pos BETWEEN ‘+str((@PageIndex-1)*@PageSize+1)+‘ AND ‘+str(@PageIndex*@PageSize)

exec (@strSQL)

.net SQLSERVER 分页存储过程

原文:https://www.cnblogs.com/hd110956/p/9202871.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!