Модераторы: Akina
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> чувствительность try catch, невосприятие ошибок одних кодов опасност 
:(
    Опции темы
Hohhi
Дата 8.11.2009, 14:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 25.2.2006
Где: Молдова

Репутация: нет
Всего: нет



нужно обработать ошибку при обращении, к переменным вне области видимости. Забавно, но при такой ошибке в 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 
PM MAIL ICQ   Вверх
Zioma
Дата 8.11.2009, 15:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 150
Регистрация: 22.8.2007

Репутация: 5
Всего: 5



Конечно есть smile

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

А ошибка деления на 0 - это ошибка выполнения. Соответственно может обработаться в програмном коде.
PM MAIL   Вверх
Hohhi
Дата 8.11.2009, 15:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 171
Регистрация: 25.2.2006
Где: Молдова

Репутация: нет
Всего: нет



Zioma, то есть ошибку с областью видимости невозможно перехватить блоком TRY…CATCH, если мы лишь исполняем некий кусок кода?
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "MS SQL"
Akina

Akina

Запрещается!

Публиковать ссылки и обсуждать взлом чего бы то ни было.

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы составления неспецифических запросов рассматриваются здесь
  • Используйте теги [code=sql][/code] для подсветки кода. Используйтe чекбокс "транслит" (возле кнопок кодов) если у Вас нет русских шрифтов.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, Akina.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MS SQL Server | Следующая тема »


 




[ Время генерации скрипта: 0.0888 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.