Выполнив запрос, получим - "ДА".
Инструкцию IIF можно применять и при вычислении выражений.
Пример:
а = b + iif(c is null, 0, с);
Инструкция INSERT INTO ... FROM ... UNION ...
Сервер Yaffil, в отличие от InterBase/Firebird, позволяет использовать объединения UNION для формирования данных на вставку. Пример:
insert into t_a (id) select b.id from b union select с.id from с
Выражения в EXCEPTION
Сервер Yaffil расширяет синтаксис инструкции exception. Допускаются три варианта использования:
* exception 'исключение'; Этот вариант соответствует синтаксисe interbase/Firebird - сервер выбрасывает исключение, заданное соответствующим идентификатором.
* exception 'исключение' 'выражение'; В этом случае сервер также выбрасывает исключение, но его текст заменяется на результат вычисления выражения.
* exception; Сервер выбрасывает последнее сформированное исключение. Если до выполнения этой инструкции исключений выброшено не было, то инструкция игнорируется. Этот вариант используется для повторного выбрасывания исключения в обработчиках ошибок WHEN.
Системные переменные ROWS_AFFECTED, GDSCODE, SQLCODE, TRANSACTIONJD, CONNECTIONJD
* Переменная ROWS_AFFECTED содержит количество записей, модифицированных в результате выполнения последнего за ipoca.
* Переменная GDSCODE содержит значения инструкции gdscode в обработчике WHEN, однако может использоваться вне контекста WHEN.
* Переменная SQLCODE содержит значения инструкции sqlcode в обработчике WHEN, однако может использоваться вне контекста WHEN.
* Переменная TRANSACTION_ID содержит номер транзакции.
* Переменная CONNECTION_ID содержит номер подключения.
Группировка по номеру столбца
Сервер Yaffil расширяет синтаксис инструкции group by. Допускается указывать номера столбцов для группировки, как в инструкции oreder by.
Пример:
select count(a), b from t group by 2
Значения переменных по умолчанию
Сервер Yaffil расширяет синтаксис инструкции declare variable. Можно не указывать ключевое слово variable и указать инициализирующее значение переменной.
Пример:
declare k = 0;
Тип данных BIGINT
Дополнительный тип данных BIGINT является аналогом типа данных NUMERIC (18.0) и предлагает более лаконичное и понятное название для 64-битного целого.
Дополнительные национальные кодовые страницы и порядки сортировки
В Yaffil добавлены следующие национальные кодовые страницы и порядки сортировки:
* CS_WIN1257 - страны Прибалтики, кодовая страница Windows - 1257
Порядки сортировки:
* WIN1257_EE - Эстония
* WIN1257_LV-литва
* WIN1257_LT- Латвия
* CS_KOI8R - Россия KOI8. кодовая страница Windows - 20866
Порядки сортировки:
* KOI8R
* KOI8R_RU
* CS_KOI8U - Украина KOI8-U, кодовая страница Windows - 21866
Порядки сортировки:
* KOI8U
* KOI8LLUA
Также для кодовой страницы WIN 1251 добавлены порядки сортировки:
* WIN1251_UA
* WIN1251_RU
Группировка по встроенным функциям и UDF
Разрешена группировка и использование встроенных функций и UDF.
Пример:
select sum(vent) from sales group by extract(year from sale date)
Ограничение результатов выборки FIRST/SKIP