Oracle SQL. 100 шагов от новичка до профессионала. 20 дней новых знаний и практики. Максим Михайлович Чалышев
ситуации, например при делении некоторого значения на ноль: в этом случае запрос выдает некорректный результат или вообще не выполняется, но при этом некоторые среды разработки подавляют сообщения об ошибке.
Об этом следует помнить, когда вы пишете запросы, использующие математические выражения.
Вопросы учеников
Зачем использовать псевдонимы для колонок, которые рассчитываются как математические выражения?
Для удобного, понятного отображения названия колонки.
Где найти полный перечень математических функций, поддерживаемых СУБД?
В документации по вашей СУБД.
Контрольные вопросы и задания для самостоятельного выполнения
1. Вывести из таблицы MAN имя, фамилию и квадратный корень 10.
2. Вывести из таблицы MAN имя, фамилию и возраст человека, умноженный на cos (5).
3. Вывести из таблицы CITY записи (*), где популяция делится без остатка на 10 000.
4. Вывести из таблицы CITY название города, квадратный корень от популяции, умноженный на 10, где значение кода города делится нацело на 3.
Продолжением данного шага является следующий шаг, посвященный таблице DUAL.
Шаг 22. Запрос к результату выражения и специальная таблица DUAL
Введение
В SQL ORACLE диалекта есть специальная таблица DUAL. Если в других СУБД существуют альтернативные варианты синтаксиса, то для SQL ORACLE необходимо использовать таблицу DUAL.
Теория и практика
Данная таблица выполняет следующие задачи:
• делает удобным вывод в запросе «результаты вычислений математического выражения»;
• помогает при вычислении функции, которая возвращает одно значение.
При этом для результата вычисления данных выражений нам не требуется участие колонок из каких-либо таблиц в нашей базе данных.
Разберем на примерах:
Вычислить значение математического выражения 1000* (123—11) /100 с помощью SELECT.
Рисунок 46. Вычисление выражения
Вычислить значение функции sIN (10) /100 с помощью SELECT.
Рисунок 47. Вычисление выражения, таблица DUAL
Вычислить значение текущей даты с помощью SELECT.
– 21.11.1999 11:22
Вычислить значение sIN (1) *cos (1) с помощью SELECT.
Рисунок 48. Вычисление выражения и таблица sIN (1) * cos (1)
Важные замечания
При обращении к таблице DUAL запрос возвращает всего одну строку, при попытке добавить запись в таблицу DUAL могут произойти непредсказуемые последствия, не рекомендую это делать.
Вопросы учеников
Вы говорили, что в других СУБД, например MS SQL, можно обойтись без таблицы DUAL?
Да в MS SQL, например, будет работать такой запрос: SELECT sIN (1), здесь нет FROM, ORACLE в этом случае более соответствует стандарту SQL ANSI 92.
Контрольные вопросы и задания для самостоятельного выполнения
1. Вычислить значение площади квадрата со стороной 5 с помощью