Терадата - CASE и COALESCE

В этой главе объясняются функции CASE и COALESCE Teradata.

CASE выражение

Выражение CASE оценивает каждую строку по условию или предложению WHEN и возвращает результат первого совпадения. Если совпадений нет, возвращается результат из части ELSE.

Синтаксис

Ниже приводится синтаксис выражения CASE.

CASE <expression> 
WHEN <expression> THEN result-1 
WHEN <expression> THEN result-2 

ELSE  
   Result-n 
END

пример

Рассмотрим следующую таблицу сотрудников.

Работник № Имя Фамилия Дата присоединения Отдел Нет День рождения
101 Майк Джеймс 27.03.2005 1 05.01.1980
102 Роберт Уильямс 25.04.2007 2 05.03.1983
103 Питер Павел 21.03.2007 2 01.04.1983
104 Alex Стюарт 01.02.2008 2 06.11.1984
105 Роберт Джеймс 04.01.2008 3 01.12.1984

В следующем примере оценивается столбец DepartmentNo и возвращается значение 1, если номер отдела равен 1; возвращает 2, если номер отдела равен 3; в противном случае он возвращает значение как недопустимый отдел.

SELECT 
   EmployeeNo, 
CASE DepartmentNo 
   WHEN 1 THEN 'Admin' 
   WHEN 2 THEN 'IT' 
ELSE 'Invalid Dept'
   END AS Department 
FROM Employee;

Когда вышеуказанный запрос выполняется, он дает следующий результат.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo    Department 
-----------   ------------ 
   101         Admin 
   104         IT 
   102         IT 
   105         Invalid Dept 
   103         IT

Вышеупомянутое выражение CASE также можно записать в следующей форме, которая даст тот же результат, что и выше.

SELECT 
   EmployeeNo, 
CASE  
   WHEN DepartmentNo = 1 THEN 'Admin' 
   WHEN  DepartmentNo = 2 THEN 'IT' 
ELSE 'Invalid Dept' 
   END AS Department  
FROM Employee;

КОАЛЕС

COALESCE - это инструкция, которая возвращает первое ненулевое значение выражения. Он возвращает NULL, если все аргументы выражения имеют значение NULL. Ниже приводится синтаксис.

Синтаксис

COALESCE(expression 1, expression 2, ....)

пример

SELECT 
   EmployeeNo, 
   COALESCE(dept_no, 'Department not found') 
FROM  
   employee;

NULLIF

Оператор NULLIF возвращает NULL, если аргументы равны.

Синтаксис

Ниже приводится синтаксис оператора NULLIF.

NULLIF(expression 1, expression 2)

пример

В следующем примере возвращается NULL, если DepartmentNo равно 3. В противном случае возвращается значение DepartmentNo.

SELECT 
   EmployeeNo,  
   NULLIF(DepartmentNo,3) AS department 
FROM Employee;

Приведенный выше запрос возвращает следующие записи. Вы можете видеть, что у сотрудника 105 нет отдела. как NULL.

*** Query completed. 5 rows found. 2 columns returned. 
*** Total elapsed time was 1 second. 
 EmployeeNo      department 
-----------  ------------------ 
    101              1 
    104              2 
    102              2 
    105              ? 
    103              2