Использование функций преобразования

Помимо служебных функций SQL, встроенная библиотека функций Oracle содержит функции преобразования типов. Могут быть сценарии, в которых запрос ожидает ввода в определенном типе данных, но получает его в другом типе данных. В таких случаях Oracle неявно пытается преобразовать неожиданное значение в совместимый тип данных, который можно заменить на месте, и непрерывность приложения не будет нарушена. Преобразование типов может быть выполнено Oracle неявно или явно программистом.

Неявное преобразование типов данных работает на основе матрицы, которая демонстрирует поддержку Oracle внутреннего преобразования типов. Помимо этих правил Oracle предлагает функции преобразования типов, которые можно использовать в запросах для явного преобразования и форматирования. Фактически, рекомендуется выполнять явное преобразование вместо того, чтобы полагаться на программный интеллект. Хотя неявное преобразование работает хорошо, но для устранения вероятности перекоса, когда неверные входные данные могут быть трудными для внутреннего преобразования типов.

Неявное преобразование типа данных

Значение VARCHAR2 или CHAR может быть неявно преобразовано Oracle в значение типа NUMBER или DATE. Точно так же значение типа NUMBER или DATA может быть автоматически преобразовано в символьные данные сервером Oracle. Обратите внимание, что неявное взаимное преобразование происходит только тогда, когда символ представляет действительное число или значение типа даты соответственно.

Например, рассмотрите приведенные ниже запросы SELECT. Оба запроса дадут одинаковый результат, потому что Oracle внутренне обрабатывает 15000 и 15000 как одно и то же.

Запрос-1

SELECT employee_id,first_name,salary
FROM employees
WHERE salary > 15000;

Запрос-2

SELECT employee_id,first_name,salary
FROM employees
WHERE salary > '15000';

Явное преобразование типа данных

Функции преобразования SQL - это однорядные функции, которые могут приводить к типу значение столбца, литерал или выражение. TO_CHAR, TO_NUMBER и TO_DATE - три функции, которые выполняют перекрестную модификацию типов данных.

Функция TO_CHAR

Функция TO_CHAR используется для приведения числового ввода или ввода даты к символьному типу с моделью формата (необязательно).

Синтаксис

TO_CHAR(number1, [format], [nls_parameter])

Для преобразования числа в символы можно использовать параметры nls, чтобы указать десятичные символы, разделитель групп, модель местной валюты или модель международной валюты. Это необязательная спецификация - если она недоступна, будут использоваться настройки nls уровня сеанса. Для преобразования даты в символы можно использовать параметр nls для указания названия дня и месяца, если это применимо.

Даты могут быть отформатированы в нескольких форматах после преобразования в символьные типы с помощью функции TO_CHAR. Функция TO_CHAR используется для отображения дат в Oracle 11g в определенном формате. Модели формата чувствительны к регистру и должны быть заключены в одинарные кавычки.

Рассмотрим приведенный ниже запрос SELECT. Запрос форматирует столбцы HIRE_DATE и SALARY таблицы EMPLOYEES с помощью функции TO_CHAR.

SELECT first_name,
       TO_CHAR (hire_date, 'MONTH DD, YYYY') HIRE_DATE,
	   TO_CHAR (salary, '$99999.99') Salary
FROM employees
WHERE rownum < 5;

FIRST_NAME           HIRE_DATE          SALARY
-------------------- ------------------ ----------
Steven               JUNE      17, 2003  $24000.00
Neena                SEPTEMBER 21, 2005  $17000.00
Lex                  JANUARY   13, 2001  $17000.00
Alexander            JANUARY   03, 2006   $9000.00

Первый TO_CHAR используется для преобразования даты найма в формат даты МЕСЯЦ ДД, ГГГГ, т.е. месяц, записанный по буквам и дополненный пробелами, за которым следует день месяца из двух цифр, а затем год из четырех цифр. Если вы предпочитаете отображать название месяца в смешанном регистре (то есть «декабрь»), просто используйте этот регистр в аргументе формата: ('Месяц ДД, ГГГГ').

Вторая функция TO_CHAR на рис. 10-39 используется для форматирования ЗАРПЛАТЫ для отображения знака валюты и двух десятичных знаков.

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

Модель формата Описание
, (запятая) Он возвращает запятую в указанной позиции. Вы можете указать несколько запятых в модели числового формата. Ограничения: элемент запятой не может начинать модель числового формата. Запятая не может появляться справа от десятичного знака или точки в модели числового формата.
. (период) Возвращает десятичную точку, которая является точкой (.) В указанной позиции. Ограничение: в модели числового формата можно указать только один период.
$ Возвращает значение со знаком доллара в начале.
0 Возвращает ведущие нули. Возвращает нули в конце.
9 Возвращает значение с указанным количеством цифр с пробелом в начале, если оно положительное, или с начальным минусом, если оно отрицательное. Начальные нули не заполнены, за исключением нулевого значения, которое возвращает ноль для целой части числа с фиксированной запятой.
B Возвращает пробелы для целой части числа с фиксированной точкой, когда целая часть равна нулю (независимо от «0» в модели формата).
C Возвращает в указанной позиции символ валюты ISO (текущее значение параметра NLS_ISO_CURRENCY).
D Возвращает в указанной позиции десятичный символ, который является текущим значением параметра NLS_NUMERIC_CHARACTER. По умолчанию - точка (.). Ограничение: в модели числового формата можно указать только один десятичный символ.
EEE Возвращает значение в экспоненциальной нотации.
FM Возвращает значение без начальных и конечных пробелов.
г Возвращает в указанной позиции разделитель групп (текущее значение параметра NLS_NUMERIC_CHARACTER). Вы можете указать несколько разделителей групп в модели числового формата. Ограничение: разделитель групп не может появляться справа от десятичного символа или точки в модели числового формата.
L Возвращает в указанной позиции символ местной валюты (текущее значение параметра NLS_CURRENCY).
MI Возвращает отрицательное значение со знаком минус в конце (-). Возвращает положительное значение с пробелом в конце. Ограничение: элемент формата MI может появляться только в последней позиции модели числового формата.
PR Возвращает отрицательное значение в формате. Он может появиться только в конце модели числового формата.
РН, пог.м Возвращает значение в виде римских цифр в верхнем регистре. Возвращает значение в виде римских цифр в нижнем регистре. Значение может быть целым числом от 1 до 3999.
S Возвращает отрицательное значение со знаком минус в начале или в конце (-). Возвращает положительное значение со знаком плюс (+) в начале или в конце. Ограничение: элемент формата S может появляться только в первой или последней позиции модели числового формата.
TM «Текстовый минимум». Возвращает (в десятичном формате) наименьшее возможное количество символов. Этот элемент нечувствителен к регистру.
U Возвращает в указанной позиции символ двойной валюты "евро" (или другую) (текущее значение параметра NLS_DUAL_CURRENCY).
V Возвращает значение, умноженное на 10n (и, если необходимо, округляет его в большую сторону), где n - количество девяток после буквы «V».
Икс Возвращает шестнадцатеричное значение указанного количества цифр.

TO_NUMBER функция

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

Синтаксис

TO_NUMBER (string1, [format], [nls_parameter])

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

Модель формата Описание
CC Век
SCC Век до нашей эры с префиксом -
ГГГГ Год с 4 числами
SYYY Год до н.э. с префиксом -
ГГГГ Год ISO с 4 числами
YY Год с 2 числами
RR Год с 2 числами с совместимостью с 2000 годом
ГОД Год в иероглифах
SYEAR Год символами, BC с префиксом -
до н.э Индикатор BC / AD
Q Квартал в цифрах (1,2,3,4)
ММ Месяц года 01, 02 ... 12
МЕСЯЦ Месяц в символах (например, январь)
ПН ЯНВАРЬ, ФЕВРАЛЬ
WW Номер недели (например, 1)
W Номер недели месяца (например, 5)
IW Номер недели года в стандарте ISO.
DDD День года в цифрах (например, 365)
DD День месяца цифрами (например, 28)
D День недели в цифрах (например, 7)
ДЕНЬ День недели символами (например, понедельник)
FMDAY День недели символами (например, понедельник)
DY Краткое описание дня недели (например, СОЛНЦЕ)
J Юлианский день (количество дней с 1 января 4713 г. до н.э., где 1 января 4713 г. до н.э. соответствует 1 в Oracle)
HH, H12 Часовой номер дня (1-12)
HH24 Часовой номер дня в 24-часовом формате (0-23)
ДО ПОЛУДНЯ ПОСЛЕ ПОЛУДНЯ До или после полудня
СКУЧАТЬ Количество минут и секунд (например, 59),
SSSSS Количество секунд в этот день.
DS Краткий формат даты. Зависит от NLS-настроек. Используйте только с отметкой времени.
DL Длинный формат даты. Зависит от NLS-настроек. Используйте только с отметкой времени.
E Сокращенное название эпохи. Действительно только для календарей: Японский Императорский, Официальный РПЦ, Тайский Будда.
EE Полное название эпохи
FF Доли секунды. Используйте с отметкой времени.
FF1..FF9 Доли секунды. Используйте с отметкой времени. Цифра определяет количество десятичных цифр, используемых в долях секунды.
FM Режим заполнения: подавляет пропуски при преобразовании.
FX Точный формат: требуется точное соответствие шаблонов между данными и моделью формата.
МГГ ИЛИ МГ ИЛИ Я Последние 3,2,1 цифры года по стандарту ISO. Только вывод
RM Римские цифры месяца (I .. XII)
RR Последние 2 цифры года.
RRRR Последние 2 цифры года, когда используются для вывода. При использовании для ввода принимает годы, состоящие из четырех цифр.
SP Написанный формат. Может появляться в конце числового элемента. Результат всегда на английском. Например, месяц 10 в формате MMSP возвращает «десять».
SPTH Орфографический и порядковый формат; 1 результатов в первые.
TH Преобразует число в его порядковый формат. Например, 1 становится 1-м.
TS Кратковременный формат. Зависит от NLS-настроек. Используйте только с отметкой времени.
TZD Сокращенное название часового пояса. то есть PST.
ТЖ, ТЗМ Смещение часов / минут часового пояса.
TZR Регион часового пояса
Икс Знак местного основания. В Америке это период (.)

Запросы SELECT ниже принимают числа в качестве входных символов и выводят их после спецификатора формата.

SELECT  TO_NUMBER('121.23', '9G999D99') 
FROM DUAL

TO_NUMBER('121.23','9G999D99')
------------------------------
                        121.23

SELECT  TO_NUMBER('1210.73', '9999.99') 
FROM DUAL;

TO_NUMBER('1210.73','9999.99')
------------------------------
                       1210.73

TO_DATE функция

Функция принимает в качестве входных данных значения символов и возвращает эквивалентную дату в формате. Функция TO_DATE позволяет пользователям вводить дату в любом формате, а затем преобразовывает запись в формат по умолчанию, используемый Oracle 11g.

Синтаксис:

TO_DATE( string1, [ format_mask ], [ nls_language ] )

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

Модель формата Описание
ГОД Год, прописанный
ГГГГ 4-значный год
ГГГ, ГГ, Г Последние 3, 2 или 1 цифра года.
IYY, IY, я Последние 3, 2 или 1 цифры года по ISO.
ГГГГ 4-значный год на основе стандарта ISO
RRRR Принимает год из 2 цифр и возвращает год из 4 цифр.
Q Квартал года (1, 2, 3, 4; ЯНВАРЬ-МАРТ = 1).
ММ Месяц (01-12; ЯНВАРЬ = 01).
ПН Сокращенное название месяца.
МЕСЯЦ Название месяца, дополненное пробелами длиной до 9 знаков.
RM Римская цифра месяц (I-XII; JAN = I).
WW Неделя года (1-53), где первая неделя начинается в первый день года и продолжается до седьмого дня года.
W Неделя месяца (1–5), где первая неделя начинается в первый день месяца и заканчивается седьмого числа.
IW Неделя в году (1-52 или 1-53) в соответствии со стандартом ISO.
D День недели (1-7).
ДЕНЬ Название дня.
DD День месяца (1-31).
DDD День года (1-366).
DY Сокращенное название дня.
J Юлианский день; количество дней с 1 января 4712 г. до н.э.
HH12 Час дня (1-12).
HH24 Час дня (0-23).
СКУЧАТЬ Минута (0-59).
SSSSS Секунды после полуночи (0-86399).
FF Дробные секунды. Используйте значение от 1 до 9 после FF, чтобы указать количество цифр в долях секунды. Например, «FF4».
ДО ПОЛУДНЯ ПОСЛЕ ПОЛУДНЯ Индикатор меридиана
Н.э., Британская Колумбия Индикатор AD, BC
TZD Информация о переходе на летнее время. Например, "PST"
ТЖ, ТЗМ, ТЗР Часовой пояс, час / минута / регион.

В следующем примере строка символов преобразуется в дату:

SELECT TO_DATE('January 15, 1989, 11:00 A.M.',  'Month dd, YYYY, HH:MI A.M.',  'NLS_DATE_LANGUAGE = American')
FROM DUAL;

TO_DATE('
---------
15-JAN-89

Общие функции

Общие функции используются для обработки значений 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