SQL Server 2000存储Proc爆炸没有明显的原因

Kri*_*ris 0 sql stored-procedures sql-server-2000

如果它总是炸弹或一些错误 - 任何帮助将非常感激.

CREATE PROCEDURE sp_LetsWork
  (@MYID int,  @ThisDate Datetime)
AS
  SET NOCOUNT ON

  DECLARE @intErrorCode int,  
          @QStartDate datetime, 
          @QEndDate datetime 

  SELECT @intErrorCode = @@ERROR

  --DATEPART(mm, @ThisDate) BETWEEN  1 and 3 -- test both options
  BEGIN
    IF @ThisDate BETWEEN '01/01/' + CONVERT(VARCHAR(4), YEAR(@ThisDate)) 
                         AND '03/31/' + CONVERT(VARCHAR(4), YEAR(@ThisDate))  
    RunQuarter:
        SELECT * 
        FROM qryAR 
        WHERE CID = @MYID 
          AND (paiddate >= @QStartDate 
          AND paiddate <= @QEndDate)
        --ORDER BY paiddate ASC

        GO
        -- GOTO RunQuarter
  END
  GO

  SELECT @intErrorCode = @@ERROR

  IF (@intErrorCode <> 0) GOTO ErrHandler

  RETURN 0

ErrHandler:

  RETURN @intErrorCode

GO  
Run Code Online (Sandbox Code Playgroud)

gbn*_*gbn 7

GO在存储过程中有一半.

GO 不是SQL:它告诉客户端工具,如SSMS批处理结束

所以误差 paiddate <=@QEndDate),因为这是由于存储过程的末尾GO:没有匹配ENDBEGIN上述这

它不是"轰炸"执行,因为它没有被创建......