Использование условных выражений
Общие функции
Общие функции используются для обработки значений NULL в базе данных. Целью общих функций обработки NULL является замена значений NULL альтернативным значением. Мы кратко рассмотрим эти функции ниже.
NVL
Функция NVL заменяет значение NULL альтернативным значением.
Синтаксис:
NVL( Arg1, replace_with )
В синтаксисе оба параметра обязательны. Обратите внимание, что функция NVL работает со всеми типами данных. А также, что тип данных исходной строки и замены должны быть в совместимом состоянии, то есть быть одинаковыми или неявно конвертируемыми Oracle.
Если arg1 является символьным значением, то oracle преобразует заменяющую строку в тип данных, совместимый с arg1, прежде чем сравнивать их, и возвращает VARCHAR2 в наборе символов expr1. Если arg1 является числовым, Oracle определяет аргумент с наивысшим числовым приоритетом, неявно преобразует другой аргумент в этот тип данных и возвращает этот тип данных.
В приведенном ниже операторе SELECT будет отображаться «n / a», если сотрудник еще не назначен на какое-либо задание, т.е. JOB_ID равен NULL. В противном случае будет отображаться фактическое значение JOB_ID.
SELECT first_name, NVL(JOB_ID, 'n/a')
FROM employees;
NVL2
В качестве усовершенствования по сравнению с NVL Oracle представила функцию для замены значения не только для значений столбцов NULL, но и для столбцов NOT NULL. Функция NVL2 может использоваться для замены альтернативного значения NULL, а также значения, отличного от NULL.
Синтаксис:
NVL2( string1, value_if_NOT_null, value_if_null )
В операторе SELECT ниже будет отображаться «Bench», если JOB_CODE для сотрудника равен NULL. Для определенного ненулевого значения КОД ЗАДАНИЯ будет отображаться постоянное значение «Назначено задание».
SQL> SELECT NVL2(JOB_CODE, 'Job Assigned', 'Bench')
FROM employees;
NULLIF
Функция NULLIF сравнивает два аргумента expr1 и expr2. Если expr1 и expr2 равны, возвращается NULL; в противном случае он возвращает expr1. В отличие от другой функции обработки NULL, первый аргумент не может быть NULL.
Синтаксис:
NULLIF (expr1, expr2)
Обратите внимание, что первый аргумент может быть выражением, которое оценивается как NULL, но не может быть буквальным NULL. Оба параметра являются обязательными для выполнения функции.
Следующий запрос возвращает NULL, поскольку оба входных значения, 12, равны.
SELECT NULLIF (12, 12)
FROM DUAL;
Точно так же запрос ниже возвращает «SUN», поскольку обе строки не равны.
SELECT NULLIF ('SUN', 'MOON')
FROM DUAL;
КОАЛЕС
Функция COALESCE, более общая форма NVL, возвращает первое ненулевое выражение в списке аргументов. Требуется минимум два обязательных параметра, но максимальное количество аргументов не имеет ограничений.
Синтаксис:
COALESCE (expr1, expr2, ... expr_n )
Рассмотрим приведенный ниже запрос SELECT. Он выбирает первое ненулевое значение, введенное в поля адреса для сотрудника.
SELECT COALESCE (address1, address2, address3) Address
FROM employees;
Интересно, что работа функции COALESCE аналогична конструкции IF..ELSIF..ENDIF. Запрос выше можно переписать как -
IF address1 is not null THEN
result := address1;
ELSIF address2 is not null THEN
result := address2;
ELSIF address3 is not null THEN
result := address3;
ELSE
result := null;
END IF;
Условные функции
Oracle предоставляет условные функции DECODE и CASE для наложения условий даже в операторе SQL.
Функция ДЕКОДИРОВАТЬ
Функция является эквивалентом условного процедурного оператора IF..THEN..ELSE в SQL. DECODE работает со значениями / столбцами / выражениями всех типов данных.
Синтаксис:
DECODE (expression, search, result [, search, result]... [, default])
Функция DECODE сравнивает выражение с каждым поисковым значением по порядку. Если между выражением и аргументом поиска существует равенство, он возвращает соответствующий результат. В случае отсутствия совпадений возвращается значение по умолчанию, если оно определено, иначе NULL. В случае несоответствия совместимости любого типа, oracle внутренне выполняет возможное неявное преобразование для возврата результатов.
Фактически, Oracle считает два нуля эквивалентными при работе с функцией DECODE.
SELECT DECODE(NULL,NULL,'EQUAL','NOT EQUAL')
FROM DUAL;
DECOD
-----
EQUAL
Если выражение равно нулю, Oracle возвращает результат первого поиска, который также равен нулю. Максимальное количество компонентов в функции DECODE - 255.
SELECT first_name, salary, DECODE (hire_date, sysdate,'NEW JOINEE','EMPLOYEE')
FROM employees;
CASE выражение
Выражения CASE работают по той же концепции, что и DECODE, но отличаются синтаксисом и использованием.
Синтаксис:
CASE [ expression ]
WHEN condition_1 THEN result_1
WHEN condition_2 THEN result_2
...
WHEN condition_n THEN result_n
ELSE result
END
Поиск Oracle начинается слева и перемещается вправо, пока не найдет истинное условие, а затем возвращает связанное с ним выражение результата. Если не найдено ни одного условия, которое является истинным, и существует предложение ELSE, Oracle возвращает результат, определенный с помощью else. В противном случае Oracle возвращает null.
Максимальное количество аргументов в выражении CASE - 255. В этот предел учитываются все выражения, включая начальное выражение простого выражения CASE и необязательное выражение ELSE. Каждая пара WHEN ... THEN считается двумя аргументами. Чтобы избежать превышения этого предела, вы можете вкладывать выражения CASE, чтобы само return_expr было выражением CASE.
SELECT first_name, CASE WHEN salary < 200 THEN 'GRADE 1'
WHEN salary > 200 AND salary < 5000 THEN 'GRADE 2'
ELSE 'GRADE 3'
END CASE
FROM employees;
ENAM CASE
---- -------
JOHN GRADE 2
EDWIN GRADE 3
KING GRADE 1