В разных системах имеется различное число встроенных функций, упрощающих работу с датами, строками и другими типами данных. Внешне дата может быть представлена строками различных форматов
Например:
“October 27, 1995”
“27-OCT-1994”
“10-27-95”
“10/27/95”
“27.10.95”
Кроме абсолютных дат, в SQL-выражениях можно также пользоваться относительным заданием дат:
“yesterday” вчера
“today” сегодня
“now” сейчас (включая время)
“tomorrow” завтра
Дата может неявно конвертироваться в строку (из строки), если:
• строка, представляющая дату, имеет один из вышеперечисленных форматов;
• выражение не содержит неоднозначностей в толковании типов столбцов.
Запрос: получить список сотрудников, принятых на работу после 1 января 1994 года
SELECT first_name, last_name, hire_date
FROM employee
WHERE hire_date > '1-1-94';
Результат запроса:
FIRST_NAME LAST_NAME HIRE_DATE
=============== ===================
Pierre Osborne 3-JAN-1994
John Montgomery 30-MAR-1994
Mark Guckenheimer 2-MAY-1994
Значения дат можно сравнивать друг с другом, сравнивать с относительными датами, вычитать одну дату из другой.
Запрос: получить список служащих, проработавших на предприятии к настоящему времени более 7 лет
SELECT first_name, last_name, hire_date
FROM employee
WHERE 'today' - hire_date > 365 * 7 + 1;
Результат запроса:
FIRST_NAME LAST_NAME HIRE_DATE
=============== ===================
Robert Nelson 28-DEC-1988
Bruce Young 28-DEC-1988