select top @varible

        在MS SQL Server 2K5中写的一个存储过程如下:
CREATE PROCEDURE [dbo].[GetRecentNews]
     @SchoolID int,
     @NewsType int,
     @PageSize tinyint,
     @Page int
AS
 --分页
 if(NewsType=0)
     SELECT TOP @PageSize ID,Title,UpdateTime FROM News WHERE  SchoolID=@SchoolID AND ID NOT IN
  (SELECT TOP @PageSize*(@Page-1) ID FROM News WHERE SchoolID=@SchoolID  ORDER BY UpdateTime DESC)  ORDER BY UpdateTime DESC  
 else
     SELECT TOP @PageSize ID,Title,UpdateTime FROM News WHERE  SchoolID=@SchoolID AND NewsType=@NewsType AND ID NOT IN
  (SELECT TOP @PageSize*(@Page-1) ID FROM News WHERE SchoolID=@SchoolID AND NewsType=@NewsType ORDER BY UpdateTime DESC)  ORDER BY UpdateTime DESC

   RETURN
GO


      在SQL Server 2K5中没有问题,但到了Sql Server 2K中,却报错:
服务器: 消息 170,级别 15,状态 1,过程 GetRecentNews,行 9
第 9 行: '@PageSize' 附近有语法错误。
服务器: 消息 170,级别 15,状态 1,过程 GetRecentNews,行 10
第 10 行: '@PageSize' 附近有语法错误。
服务器: 消息 170,级别 15,状态 1,过程 GetRecentNews,行 13
第 13 行: '@PageSize' 附近有语法错误。

     晕!Sql Server 2K中写法如下:
CREATE PROCEDURE [dbo].[GetRecentNews]
 @SchoolID int,
 @NewsType int,
 @PageSize int,
 @Page int
AS
 --分页
 declare @current int
 set @current= @PageSize*(@Page-1)
 if (@NewsType=0)
     exec('SELECT TOP ' + @PageSize +' ID,Title,UpdateTime FROM News WHERE  SchoolID='+ @SchoolID +' AND ID NOT IN
  (SELECT TOP ' + @current +' ID FROM News WHERE SchoolID='+@SchoolID+' ORDER BY UpdateTime DESC)
  ORDER BY UpdateTime DESC')
 else
     exec('SELECT TOP ' + @PageSize +' ID,Title,UpdateTime FROM News WHERE  SchoolID='+ @SchoolID +' AND NewsType='+ @NewsType +' AND ID NOT IN
  (SELECT TOP ' + @current +' ID FROM News WHERE SchoolID='+@SchoolID+' AND NewsType='+@NewsType+' ORDER BY UpdateTime DESC)
  ORDER BY UpdateTime DESC')
 return
GO

转载于:https://www.cnblogs.com/happyhippy/archive/2007/01/29/633119.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值