Před časem jsem zde na webu zveřejnil článek o RAISERROR příkazu, který vyvolá exception s tím, že jsme schopni přes severity (závažnost) ovlivnit, jestli skript bude nebo nebude pokračovat dále. Příkaz THROW je alternativní příkaz, který byl poprvé uveden v rámci SQL Server 2012.

Syntaxe THROW v SQL Server

Syntaxe je v porovnání s RAISERROR jednodušší. Pro přehled zde napíšu syntaxi obou příkazů.

RAISERROR (msg ,severity, state)

vs

BEGIN TRY
  SELECT 1/0
END TRY
BEGIN CATCH
THROW [ { error_number | @local_variable },
        { message | @local_variable },
        { state | @local_variable } ]
       [ ; ]

END CATCH

Zatímto RAISERROR přijímá 3 argumenty, tak THROW se může (ale nemusí) volat samostatně – uvnitř  TRY/CATCH error handling konstrukce. V případě, že se pokusíme příkaz spustit jen tak, výsledkem bude chyba:

THROW excepltion

Mimo TRY/CATCH blok lze příkaz použít třeba takto

THROW 51000, ‘The record does not exist.’, 1;

5/5 - (1 vote)

Ing. Jan Zedníček - Data & Finance

Jmenuji se Honza Zedníček a působím jako freelancer. Tuto práci dělám pro různé firmy již přes 10 let. Před tím jsem dlouhou dobu pracoval také jako BI developer, finanční controller a analytik. Vše pro společnosti z oblasti IT, bankovnictví a výroby. Po práci si rád zahraju tenis, volejbal, šachy a zajdu do posilovny. Svoje znalosti a názory se snažím už několik let zapisovat na tento web, aby sloužily i někomu dalšímu - zejména studentům a zájemcům o informace z oblastí Business intelligence, korporátních financí a reportingu.

=> Přihlašte se do naší Excel facebook skupiny (1.4k+ členů), kde si pomáháme Excel CZ/SK diskuse »
=> Pokud vám článek pomohl, sdílejte ho nebo mě uveďte na vašich webových stránkách jako užitečný zdroj informací.

Leave a Reply

Your email address will not be published. Required fields are marked *