SQL ISNULL a COALESCE funkce – jaké jsou rozdíly a použítí

ISNULL a COALESCE jsou funkce, které slouží k práci s prázdnými hodnotami (NULL). Obě funkce vrací první hodnotu, která je různá od NULL z předem nadefinovaných vstupních parametrů. Mezi oběma funkcemi jsou ale rozdíly.

Syntaxe ISNULL

SELECT ISNULL(<Sloupec>, <Náhradní Sloupec/Hodnota 1>)
FROM dbo.Tabulka

Syntaxe COALESCE

SELECT COALESCE(<Sloupec>, <Náhradní Sloupec/Hodnota 1>, <Náhradní Sloupec/Hodnota 2>,...)
FROM dbo.Tabulka

Rozdíly mezi ISNULL a COALESCE:

  • ISNULL přijímá pouze 2 parametry, COALESCE 2 nebo více parametrů
  • ISNULL vrací výsledek v datovém typu, jakým jsou vstupní parametry. Pokud jsou všechny zadané parametry NULL, výsledkem je NULL
  • Datový typ u COALESCE je vyhodnocen dynamicky a je zvolen podle datové priority – data precedance. Pokud jsou všechny vstupy NULL, výsledkem je chyba. Více o Data precedance v článku Dava Pinala
  • ISNULL je z pohledu výkonu rychlejší

Příklad

Deklarujme si 2 proměnné @X a @Y s datovým typem VARCHAR(1) a VARCHAR(50) a porovnejme různé kombinace

DECLARE @X VARCHAR(1) = NULL
DECLARE @Y VARCHAR(50) = 'Functions COALESCE and ISNULL are great'

SELECT
COALESCE(@X, @Y) AS COALESCE_XY,
ISNULL(@X, @Y) AS ISNULL_XY,
COALESCE(@Y, @X) AS COALESCE_YX,
ISNULL(@Y, @X) AS ISNULL_YX

Isnull vs coalesce priklad

Vyhodnocení:

  1. COALESCE (X,Y) vrací plný text v datovém typu VARCHAR(50) – má přednost z hlediska data precedance
  2. ISNULL (X,Y) vrací výsledek ve VARCHAR(1) podle prvního parametru
  3. COALESCE(Y,X) vrací opět VARCHAR(50)
  4. ISNULL (Y,X) vrací VARCAHR(50) – tentokrát je delší text zadán jako první parametr

Speciální případy výsledku obou funkcí

-- 1) Výsledek je NULL
SELECT ISNULL(NULL, NULL)

-- 2a) Výsledek je Error (alespoň 1 parametr musí být výraz (Expression) různý od NULL)
SELECT COALESCE(NULL,NULL)

-- 2b) Výsledek je NULL
DECLARE @X VARCHAR(1) = NULL
DECLARE @Y VARCHAR(50) = NULL

SELECT COALESCE(@X,@Y)

5/5 - (3 votes)
Rubrika: SQL Funkce

O Ing. Jan Zedníček - Data Engineer & Controlling

Jmenuji se Honza Zedníček a působím jako data engineer freelancer. Během cca 10 let jsem zde shromáždil přes 600 IT case studies, průvodců, návodů a tipů určených zejména odborné veřejnosti, studentům a zájemcům o informace z oblastí Data Engineeringu, korporátních financí a reportingu. Zaměřuji se především na Microsoft technologie (on-prem i cloud) a různé synergické efekty v rámci jejich produktového portfolia pro dataře a finanční profesionály. Věnuji se také dalším platformám a významným hráčům z oblasti open source technologií. 🔥 Pokud vám tento článek pomohl, ocením referenci na vašem webu nebo zmínku v komunitě. A mám pro vás ještě tip: řešíte-li nějaký zapeklitý Excel problém, přihlašte se do naší Excel Facebook skupiny (2.4k+ členů), kde si pomáháme Excel CZ/SK diskuse ».

2 thoughts on “SQL ISNULL a COALESCE funkce – jaké jsou rozdíly a použítí

Leave a Reply

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