SQL IF THEN ELSE příkaz – Neplést s CASE

Poslední aktualizace:

T-SQL Příkaz IF se používá ke kontrolování toku kódu hlavně při operacích, kde pvovádíme nějaké zásahy do db (DDL, DML operace) – třeba procedury. Můžete si ho celkem jednoduše splést s CASE příkazem. Chybou bývá, že se snažíme rvát sql IF do klauzule SELECT, což je chyba.

Dotaz kde byste použili IF v příkazu SELECT vám určite nebude fungovat

SELECT IF 1=1 THEN 'Ahoj'

SQL IF

(!!!) IF se do SELECT klauzule nedává, od toho je příkaz CASE (viz. článek o CASE)

SYNTAXE SQL IF příkazu

Začínáme příkazem IF a potom hned definicí podmínky. V případě, že je podmínka Pravdivá, provede se příkaz následující za IF a pokud ne provede se příkaz za ELSE.

IF podmínka
   ...příkaz, který se provede pokud je hodnota podmínky TRUE;

ELSE
  ...příkaz, který se provede pokud je podmínka v IF FALSE;

Tato syntaxe bude fungovat, ale optimálnější je ohraničit jednotlivé příkazy BEGIN END klauzulí:

IF podmínka
  BEGIN
     ...příkaz, který se provede pokud je hodnota podmínky TRUE
  END;
ELSE
  BEGIN
     ...příkaz, který se provede pokud je podmínka v IF FALSE
  END;

(!!!) V příkazu sql IF nepíšeme “THEN”. Příkaz neumí ani ELSEIF a pokud bychom chtěli testovat více podmínek, musíme větvit nebo použít několik IF za sebou.

SQL IF THEN ELSE příkaz – Neplést s CASE
5 (100%) 1 vote[s]

Jmenuji se Honza Zedníček a nejčastěji se se mnou v civilu můžete potkat v kancelářích Kentico Software v Brně, kde působím jako BI Developer. Částečně pracuji také jako freelancer. Tuto práci dělám pro různé firmy již přes 5 let, ale Kentico je moje srdcovka ♡. Před tím jsem pracoval jako finanční controller třeba v Aero Vodochody a Sberbank nebo jako manažer dluhopisového programu v investiční skupině Unicapital. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a rád ochutnávám dobré rumy. Svoje znalosti se snažím zapisovat na tento web - abych je nezapomněl (působením rumu ^^) a sloužily i někomu dalšímu. Nebojte se položit dotaz nebo reagovat do komentáře. Přihlašte se do naší nové Excel facebook skupiny Excel CZ/SK diskuse »

Category: SQL příkazy

About Ing. Jan Zedníček - BI Developer, Finance controller

Jmenuji se Honza Zedníček a nejčastěji se se mnou v civilu můžete potkat v kancelářích Kentico Software v Brně, kde působím jako BI Developer. Částečně pracuji také jako freelancer. Tuto práci dělám pro různé firmy již přes 5 let, ale Kentico je moje srdcovka ♡. Před tím jsem pracoval jako finanční controller třeba v Aero Vodochody a Sberbank nebo jako manažer dluhopisového programu v investiční skupině Unicapital. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a rád ochutnávám dobré rumy. Svoje znalosti se snažím zapisovat na tento web - abych je nezapomněl (působením rumu ^^) a sloužily i někomu dalšímu. Nebojte se položit dotaz nebo reagovat do komentáře. Přihlašte se do naší nové Excel facebook skupiny Excel CZ/SK diskuse »

One thought on “SQL IF THEN ELSE příkaz – Neplést s CASE

  1. Lubomír

    Stručné a velice srozumitelné vysvětlení.
    Hledal jsem, proč se nepoužívá IF v select příkazech a zde je to perfektně vysvětlené 🙂
    Díky

    Reply

Leave a Reply

Your email address will not be published.

This site uses Akismet to reduce spam. Learn how your comment data is processed.