1. Nauka
  2. /
  3. Kursy
  4. /
  5. Transakcje i obsługa błędów w SQL Server

Connected

ćwiczenie

Sprawdzanie @@TRANCOUNT w konstrukcji TRY...CATCH

Właściciel konta numer 10 wygrał loterię i otrzymuje nagrodę w wysokości 200 USD. Przygotowujesz prosty skrypt, który doda te 200 USD do kolumny current_balance dla konta 10. Wydaje ci się, że wszystko napisano poprawnie, ale wolisz jeszcze raz sprawdzić swój kod.

Okazuje się, że popełniono błąd podczas dodawania kwoty: SET current_balance = 'current_balance' + 200. Wartość 'current_balance' została zapisana jako ciąg znaków zamiast nazwy kolumny – to powoduje błąd.

Tworzony skrypt powinien wycofywać wszystkie zmiany w razie błędu, sprawdzając przy tym, czy istnieje otwarta transakcja. Jeśli wszystko przebiegnie pomyślnie, transakcja powinna zostać zatwierdzona – również z weryfikacją, czy transakcja jest otwarta.

Instrukcje

100 XP
  • Rozpocznij transakcję.
  • Popraw błąd w operacji.
  • Wewnątrz bloku TRY sprawdź, czy istnieje otwarta transakcja, i zatwierdź ją.
  • Wewnątrz bloku CATCH sprawdź, czy istnieje otwarta transakcja, i wycofaj ją.