Терадата - 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