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

Использование однорядных функций для настройки вывода

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

В более широкой категории есть два типа функций:

Single Row functions- Однострочные функции - это те, которые работают с одной строкой и возвращают один результат для каждой строки. Например, функции преобразования длины и регистра являются функциями одной строки.

Multiple Row functions - Функции с несколькими строками работают с группой строк и возвращают один результат для полного набора строк. Они также известны как групповые функции.

Однострочные функции

Однострочными функциями могут быть символьные функции, числовые функции, функции даты и функции преобразования. Обратите внимание, что эти функции используются для управления элементами данных. Эти функции требуют одного или нескольких входных аргументов и работают с каждой строкой, тем самым возвращая одно выходное значение для каждой строки. Аргументом может быть столбец, литерал или выражение. Однострочные функции можно использовать в операторах SELECT, WHERE и ORDER BY. Однорядные функции могут быть -

  • General functions- Обычно содержит функции обработки NULL. Функции в этой категории: NVL, NVL2, NULLIF, COALESCE, CASE, DECODE.

  • Case Conversion functions- Принимает ввод символов и возвращает символьное значение. Функции в этой категории - ВЕРХНИЙ, НИЖНИЙ и INITCAP.

    • Функция UPPER преобразует строку в верхний регистр.

    • Функция LOWER преобразует строку в нижний регистр.

    • Функция INITCAP преобразует только начальные алфавиты строки в верхний регистр.

  • Character functions- Принимает ввод символов и возвращает числовое или символьное значение. Функции в этой категории: CONCAT, LENGTH, SUBSTR, INSTR, LPAD, RPAD, TRIM и REPLACE.

    • Функция СЦЕПИТЬ объединяет два строковых значения.

    • Функция LENGTH возвращает длину входной строки.

    • Функция SUBSTR возвращает часть строки от заданной начальной точки до конечной точки.

    • Функция INSTR возвращает числовую позицию символа или строки в заданной строке.

    • Функции LPAD и RPAD дополняют заданную строку заданным символом до определенной длины.

    • Функция TRIM обрезает строковый ввод от начала или до конца.

    • Функция REPLACE заменяет символы из входной строки заданным символом.

  • Date functions- Дата арифметические операции возвращают дату или числовые значения. Функции в категории: MONTHS_BETWEEN, ADD_MONTHS, NEXT_DAY, LAST_DAY, ROUND и TRUNC.

    • Функция MONTHS_BETWEEN возвращает количество месяцев между двумя датами.

    • Функция ADD_MONTHS добавляет число месяцев n к дате ввода.

    • Функция NEXT_DAY возвращает следующий день указанной даты.

    • Функция LAST_DAY возвращает последний день месяца входной даты.

    • Функции ROUND и TRUNC используются для округления и усечения значения даты.

  • Number functions- Принимает числовой ввод и возвращает числовые значения. В этой категории есть функции ROUND, TRUNC и MOD.

    • Функции ROUND и TRUNC используются для округления и усечения числового значения.

    • MOD используется для возврата остатка от деления между двумя числами.

Иллюстрации

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

Запрос SELECT ниже демонстрирует использование функции NVL.

SELECT first_name, last_name, salary, NVL (commission_pct,0) 
FROM employees
WHERE rownum < 5;

FIRST_NAME           LAST_NAME                     SALARY NVL(COMMISSION_PCT,0)
-------------------- ------------------------- ---------- ---------------------
Steven               King                           24000                     0
Neena                Kochhar                        17000                     0
Lex                  De Haan                        17000                     0
Alexander            Hunold                          9000                     0

Функции преобразования регистра

Запрос SELECT ниже демонстрирует использование функций преобразования регистра.

SELECT UPPER (first_name), INITCAP (last_name), LOWER (job_id)
FROM employees
WHERE rownum < 5;

UPPER(FIRST_NAME)    INITCAP(LAST_NAME)        LOWER(JOB_
-------------------- ------------------------- ----------
STEVEN               King                      ad_pres
NEENA                Kochhar                   ad_vp
LEX                  De Haan                   ad_vp
ALEXANDER            Hunold                    it_prog

Функции персонажа

Запрос SELECT ниже демонстрирует использование функции CONCAT для объединения двух строковых значений.

SELECT CONCAT (first_name, last_name) 
FROM employees
WHERE rownum < 5;

CONCAT(FIRST_NAME,LAST_NAME)
--------------------------------
EllenAbel
SundarAnde
MozheAtkinson
DavidAustin

Запрос SELECT ниже демонстрирует использование функций SUBSTR и INSTR. Функция SUBSTR возвращает часть входной строки с 1-й позиции до 5-й позиции. Функция INSTR возвращает числовую позицию символа "a" в имени.

SELECT SUBSTR (first_name,1,5), INSTR (first_name,'a')
FROM employees
WHERE rownum < 5;

SUBST INSTR(FIRST_NAME,'A')
----- ---------------------
Ellen                     0
Sunda                     5
Mozhe                     0
David                     2

Запрос SELECT ниже демонстрирует использование LPAD и RPAD для удобной печати информации о сотрудниках и вакансиях.

SELECT RPAD(first_name,10,'_')||LPAD (job_id,15,'_')
FROM employees
WHERE rownum < 5;

RPAD(FIRST_NAME,10,'_')||
-------------------------
Steven____________AD_PRES
Neena_______________AD_VP
Lex_________________AD_VP
Alexander_________IT_PROG

Числовые функции

Запрос SELECT ниже демонстрирует использование функций ROUND и TRUNC.

SELECT ROUND (1372.472,1)
FROM dual;

ROUND(1372.472,1)
-----------------
           1372.5

SELECT TRUNC (72183,-2)
FROM dual;

TRUNC(72183,-2)
---------------
          72100

Дата арифметические операции

В запросе SELECT ниже показана арифметическая функция даты, в которой учитывается разница между датой найма сотрудника и системной датой.

SELECT employee_id, (sysdate - hire_date) Employment_days
FROM employees
WHERE rownum < 5;

EMPLOYEE_ID EMPLOYMENT_DAYS
----------- ---------------
        100      3698.61877
        101      2871.61877
        102      4583.61877
        103      2767.61877

Функции даты

Запрос SELECT ниже демонстрирует использование функций MONTHS_BETWEEN, ADD_MONTHS, NEXT_DAY и LAST_DAY.

SELECT employee_id, MONTHS_BETWEEN (sysdate, hire_date) Employment_months
FROM employees
WHERE rownum < 5;

EMPLOYEE_ID EMPLOYMENT_MONTHS
----------- -----------------
        100        121.504216
        101        94.3751837
        102        150.633248
        103        90.9558289

SELECT ADD_MONTHS (sysdate, 5), NEXT_DAY (sysdate), LAST_DAY (sysdate)
FROM dual;

ADD_MONTH NEXT_DAY( LAST_DAY(
--------- --------- ---------
01-JAN-14 05-AUG-13 31-AUG-13