Чтение онлайн

ЖАНРЫ

Firebird РУКОВОДСТВО РАЗРАБОТЧИКА БАЗ ДАННЫХ

Борри Хелен

Шрифт:

результат 1 - тот результат, который будет возвращен в случае, когда значение i будет соответствовать значению 2.

результат 2- тот результат, Который будет возвращен в случае, когда значение 1 будет соответствовать значению 3 и т.д.

Возвращаемое значение

Предложение CASE возвращает единственное значение. Если не выполняется ни одно условие и не указано предложение ELSE, то возвращаемый результат будет NULL.

Замечания

Вы должны использовать одну форму синтаксиса или другую. Смешанный синтаксис

недопустим.

Использование единственного предложения условие/результат имеет смысл, только если присутствует предложение ELSE. Хотя это менее элегантно, чем использование соответствующих функций COALESCE и NULLIF.

Примеры

Следующие два примера демонстрируют, как могут быть использованы каждый из двух вариантов синтаксиса для оперирования с одним и тем же набором предикатов.

Простой синтаксис:

SELECT

о.ID,

о.Description,

CASE о.Status

WHEN 1 THEN 'confirmed'

WHEN 2 THEN 'in production'

WHEN 3 THEN 'ready'

WHEN 4 THEN 'shipped'

ELSE 'unknown status ''' || o.Status || ''''

END

FROM Orders o;

Этот синтаксис использует предикаты поиска в предложении WHEN:

SELECT

о.ID,

о.Description,

CASE

WHEN (о.Status IS NULL) THEN 'new'

WHEN (o.Status = 1) THEN 'confirmed'

WHEN (o.Status = 3) THEN 'in production'

WHEN (o.Status = 4) THEN 'ready'

WHEN (o.Status = 5) THEN 'shipped'

ELSE 'unknown status ''' || o.Status || ''''

END

FROM Orders o;

COALESCE

Функция COALESCE позволяет вычислять значение столбца с использованием серии выражений, из которых первое выражение, возвращающее непустое значение, вернет выходное значение.

Доступность

DSQL, PSQL, ISQL, ESQL, Firebird 1.5 и выше. Любая платформа.

Синтаксис

COALESCE (<значение 1> { , значение 2 [, ... значение n]})

Аргументы

значение 1 - значение столбца или выражение, которое будет вычисляться. Если это не NULL, то оно будет возвращаемым значением.

значение 2 - значение столбца или выражение, которое будет вычисляться, если значение 1 будет NULL.

значение n - последнее значение или выражение, которое будет вычисляться, если предыдущие значения в списке будут NULL.

Возвращаемое значение

Возвращает первое не NULL значение из списка.

Замечания

Функция COALESCE о может быть использована для вычисления пары условий или списка из трех или более условий.

В первом варианте (простого, двоичного) синтаксиса COALESCE (значение1, Значение2) логика вычисления эквивалентна:

CASE WHEN V1 IS NOT NULL THEN V1 ELSE V2 END

Если присутствуют три или более аргумента - COALESCE (значение1, значение2, ... значениеN), - логика вычисления эквивалентна следующей:

CASE

WHEN V1 IS NOT NULL THEN V1

ELSE COALESCE (V2,...,Vn)

END

Последнее

значение в списке должно быть задано, чтобы быть уверенным, что что-то будет возвращено.

Пример

В первом запросе если соединение не находит соответствия в таблице EMPLOYEE для TEAM_LEADER из таблицы PROJECT, то запрос вернет строку ' [Not assigned]' (Не назначено) вместо NULL, которое в противном случае должно было вернуть внешнее соединение в качестве значения FULL NAME:

SELECT

PROJ_NAME AS Projectname,

COALESCE (e. FULL_NAME, ' [Not assigned]') AS Employeename

FROM PROJECT p

LEFT JOIN EMPLOYEE e ON (e.EMP_NO = p. TEAM_LEADER) ;

В следующем запросе вычисление начинается с самой левой позиции в списке. Если присутствует значение PHONE, запрос проверяет, присутствует ли значение MOBILEPHONE, иначе он возвращает строку 'unknown' (Неопределенный):

SELECT

COALESCE(Phone, MobilePhone, 'Unknown') AS Phonenumber

FROM Relations

Связанные или похожие функции

Пользователи Firebird 1.0.x, смотрите внешние функции INVL и SNVL.

NULLIF

NULLIF возвращает NULL в случае соответствия двух непустых значений, иначе он возвращает значение подвыражения.

Доступность

DSQL, PSQL, ISQL, ESQL, Firebird 1.5 и выше. Любая платформа.

Синтаксис

NULLIF (значение 1, значение 2)

Аргументы

значение 1 - столбец или вычисляемое выражение.

значение 2- константа или выражение, с которым сравнивается значение 1. Если они соответствуют, NULLIF возвращает NOLL.

Возвращаемое значение

Возвращаемое значение будет NULL, если значение 1 и значение 2 соответствуют друг другу. ЕСЛИ нет соответствия, возвращается значение 1.

Замечания

NULLIFO является сокращением для следующего выражения CASE: CASE WHEN(VALUE_1 = value_2) THEN NULL ELSE VALUE_1 END

Пример

Этот оператор устанавливает значение столбца STOCK из таблицы PRODUCTS в ULL для всех строк, где его текущее значение равно нулю:

UPDATE PRODUCTS

SET STOCK = NULLIF(STOCK, 0)

Связанные или похожие функции

Пользователи Firebird 1.0.x, смотрите INULLIF и SNULLIF.

Определение столбцов COMPUTED BY

В спецификации таблицы вы можете создать столбцы, называемые вычисляемыми, которые хранят не "жесткие" значения, а выражение, вычисляющее значение, когда к столбцу обращается запрос. Выражение, определяемое для столбца, обычно включает значения одного или более других столбцов текущей строки или контекстные переменные сервера. Вот простая иллюстрация:

Поделиться с друзьями: