分页、排序SQL 通用存储过程(转)

ALTER   PROCEDURE  news_Showlist
(
@tblName     varchar ( 255 ),        --  表名
@strGetFields   varchar ( 1000 ),   --  需要返回的列
@fldName   varchar ( 255 ),       --  排序的字段名
@PageSize     int  ,           --  页尺寸
@PageIndex    int  ,            --  页码
@strWhere    varchar ( 1500 ),   --  查询条件(注意: 不要加where)
@Sort   varchar ( 255 )       -- 排序的方法

)
AS
declare   @strSQL     varchar ( 5000 )        --  主语句
declare   @strTmp     varchar ( 110 )         --  临时变量
declare   @strOrder   varchar ( 400 )         --  排序类型

if   @Sort   =   ' desc '
begin
set   @strTmp   =   ' <(select min '
set   @strOrder   =   '  order by  '   +   @fldName   + '  desc '
-- 如果@OrderType不是,就执行降序,这句很重要!
end
else
begin
set   @strTmp   =   ' >(select max '
set   @strOrder   =   '  order by  '   +   @fldName   + '  asc '
end
 
if   @PageIndex   =   1
begin
if   @strWhere   !=   ''   
  
begin
set   @strSQL   =   ' select top  '   +   str ( @PageSize + '   ' + @strGetFields +   '   from  '   +   @tblName
+   '  where  '   +   @strWhere   +   '   '   +   @strOrder
  
end
else
  
begin
set   @strSQL   =   ' select top  '   +   str ( @PageSize + '   ' + @strGetFields +   '   from  ' +   @tblName
+   '   ' +   @strOrder
  
end
-- 如果是第一页就执行以上代码,这样会加快执行速度
end
else
begin
-- 以下代码赋予了@strSQL以真正执行的SQL代码
set   @strSQL   =   ' select top  '   +   str ( @PageSize + '   ' + @strGetFields +   '   from  '
+   @tblName   +   '  where  '   +   @fldName   +   ''   +   @strTmp   +   ' ( ' +   @fldName   +   ' ) from
(select top 
'   +   str (( @PageIndex - 1 ) * @PageSize +   '   ' +   @fldName   +   '  from  '
+   @tblName   +   ''   +   @strOrder   +   ' ) as tblTmp) ' +   @strOrder
 
if   @strWhere   !=   ''
set   @strSQL   =   ' select top  '   +   str ( @PageSize + '   ' + @strGetFields +   '   from  '
+   @tblName   +   '  where  '   +   @fldName   +   ''   +   @strTmp   +   ' ( ' +   @fldName   +   ' ) from
(select top 
'   +   str (( @PageIndex - 1 ) * @PageSize +   '   ' +   @fldName   +   '  from  '
 
+   @tblName   +   '  where  '   +   @strWhere   +   '   ' +   @strOrder   +   ' ) as tblTmp)
and 
'   +   @strWhere   +   '   '   +   @strOrder
end
exec  ( @strSQL )
RETURN


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值