存储过程分页

None.gifCREATE PROCEDURE GetRecordFromPage
None.gif    @tblName      varchar(
255),       -- 表名
None.gif    @fldName      varchar(
255),       -- 字段名
None.gif    @PageSize     
int = 10,           -- 页尺寸
None.gif    @PageIndex    
int = 1,            -- 页码
None.gif    @IsCount      bit 
= 0,            -- 返回记录总数, 非 0 值则返回
None.gif    @OrderType    bit 
= 0,            -- 设置排序类型, 非 0 值则降序
None.gif    @strWhere     varchar(
1000= ''  -- 查询条件 (注意: 不要加 where)
None.gifAS
None.gif
None.gifdeclare @strSQL   varchar(
6000)       -- 主语句
None.gifdeclare @strTmp   varchar(
100)        -- 临时变量
None.gifdeclare @strOrder varchar(
400)        -- 排序类型
None.gif
None.gif
if @OrderType != 0
None.gifbegin
None.gif    
set @strTmp = "<(select min"
None.gif    
set @strOrder = " order by [" + @fldName +"] desc"
None.gifend
None.gif
else
None.gifbegin
None.gif    
set @strTmp = ">(select max"
None.gif    
set @strOrder = " order by [" + @fldName +"] asc"
None.gifend
None.gif
None.gif
set @strSQL = "select top " + str(@PageSize) + " * from ["
None.gif    
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
None.gif    
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
None.gif    
+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"
None.gif    
+ @strOrder
None.gif
None.gif
if @strWhere != ''
None.gif    
set @strSQL = "select top " + str(@PageSize) + " * from ["
None.gif        
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
None.gif        
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
None.gif        
+ @fldName + "] from [" + @tblName + "] where " + @strWhere + " "
None.gif        
+ @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder
None.gif
None.gif
if @PageIndex = 1
None.gifbegin
None.gif    
set @strTmp = ""
None.gif    
if @strWhere != ''
None.gif        
set @strTmp = " where " + @strWhere
None.gif
None.gif    
set @strSQL = "select top " + str(@PageSize) + " * from ["
None.gif        
+ @tblName + "]" + @strTmp + " " + @strOrder
None.gifend
None.gif
None.gif
if @IsCount != 0
None.gif    
set @strSQL = "select count(*) as Total from [" + @tblName + "]"
None.gif
None.gifexec (@strSQL)
None.gif
None.gifGO
None.gif

转载于:https://www.cnblogs.com/gjahead/archive/2006/06/23/433895.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值