Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > MS SQL Server > чувствительность try catch


Автор: Hohhi 8.11.2009, 14:26
нужно обработать ошибку при обращении, к переменным вне области видимости. Забавно, но при такой ошибке в catch он не заходит 
Код

Declare @NumberOfTitles INT, @BestPilotSurname VARCHAR(20),@BestPilotName VARCHAR(20) ; 

SELECT @BestPilotSurname=Surname,@BestPilotName =Name,@NumberOfTitles=Titles FROM (
SELECT     TOP (1) IDPilot, Surname, Name, MAX(ChampionshipTitles) AS Titles, MAX(Points) AS BestPoints
FROM         Pilots
GROUP BY IDPilot, Surname, Name, Points
ORDER BY Titles DESC, BestPoints DESC) as BestPilot
 
SELECT @BestPilotSurname,@BestPilotName,@NumberOfTitles;

GO

BEGIN TRY
SELECT @BestPilotSurname,@BestPilotName,@NumberOfTitles;


END TRY 
BEGIN CATCH
PRINT  'Переменные находятся вне области видимости';
END CATCH;



в то время как такая модификация обрабатывается:
Код


GO

BEGIN TRY
--SELECT @BestPilotSurname,@BestPilotName,@NumberOfTitles;
   SELECT 1/0;

END TRY 
BEGIN CATCH
PRINT  'Переменные находятся вне области видимости';
END CATCH;



Неужели есть уровни чувствительности к ошибкам? Помогите разобраться smile 

Автор: Zioma 8.11.2009, 15:02
Конечно есть smile

Ошибка с переменными - это ошибка компиляции. Если бы вы что-то подобное писали в какой-либо студии и компилировали прогу, то вам не дало ее скомпилировать.

А ошибка деления на 0 - это ошибка выполнения. Соответственно может обработаться в програмном коде.

Автор: Hohhi 8.11.2009, 15:11
Zioma, то есть ошибку с областью видимости невозможно перехватить блоком TRY…CATCH, если мы лишь исполняем некий кусок кода?

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)