
- •Оглавление
- •Раздел 4. Проектирование реляционных баз данных. 113
- •Раздел 5. Определение структур данных и обслуживание баз данных. 114
- •Введение
- •Раздел 1. Основы теории баз данных Тема 1: Базы данных и информационные системы. Основные понятия.
- •Понятия базы данных и информационные системы.
- •Архитектура информационной системы.
- •Понятия базы данных и информационные системы.
- •Архитектура информационной системы.
- •Тема 2: Банки данных. Системы управления базами данных.
- •Банки данных. Основные компоненты системы.
- •Классификация субд.
- •Банки данных. Основные компоненты системы.
- •Классификация субд.
- •Раздел 2. Реляционная алгебра Тема1: Реляционная алгебра. Классические операции теории множеств.
- •Тема 2: Специальные операции теории множеств.
- •Раздел 3. Модели данных. Тема 1: Классические модели данных.
- •Сетевая модель представления данных.
- •Реляционная модель представления данных.
- •Элементы реляционной модели
- •Тема 2: Связывание таблиц. Целостность связей.
- •Основные виды связи таблиц.
- •Контроль целостности связей.
- •Характеристика видов связей
- •Раздел 4. Проектирование реляционных баз данных. Тема 1: Основные принципы проектирования баз данных.
- •2. Избыточное дублирование данных и аномалии
- •3. Формирование исходного отношения.
- •Тема 2: Метод нормальных форм
- •2. Выявление зависимостей между атрибутами
- •3. Нормальные формы
- •Тема 3: Метод сущность-связь. Этапы проектирования.
- •2.Этапы проектирования
- •3.Пример проектирования бд учебной части.
- •Тема 4: Правила формирования отношений.
- •2. Формирование отношений для связи 1:м
- •3. Формирование отношений для связи м:м
- •Раздел 5. Определение структур данных и обслуживание баз данных. Тема 1: Среда sql*Plus.
- •Функции.
- •2. Основные типы данных
- •3. Арифметические выражения
- •4. Операторы сравнения
- •5. Обработка неопределенных значений
- •6. Функции
- •7. Форматные модели
- •Тема 2: Структуры данных. Создание таблиц.
- •Создание таблиц.
- •3. Создание таблиц
- •Тема 3: Изменение таблиц и ограничений
- •Добавление и изменение столбца.
- •Изменение ограничений.
- •Удаление таблицы. Изменение имени таблицы и добавление комментариев.
- •Тема 4: Операции с ограничениями.
- •Тема 5: Манипулирование данными.
- •1. Вставка новых строк в таблицу
- •2. Копирование строк из другой таблицы
- •3. Обновление строк в таблице
- •4. Удаление строк из таблицы
- •Тема 6: Команда запроса данных. Простой запрос.
- •Тема 7: Сложные запросы.
- •Использование функций для работы с датами при организации запроса.
- •Тема 8: Группировка строк в запросе
- •2. Группы внутри групп.
- •3. Предложение having.
- •Тема 9: Подзапросы.
- •Подзапрос. Его назначение и синтаксис.
- •Однострочные и многострочные подзапросы.
- •Подзапрос. Его назначение и синтаксис.
- •2.Однострочные и многострочные подзапросы.
- •Тема 10: Выборка данных из нескольких таблиц.
- •2. Псевдонимы таблиц.
- •3. Дополнительные условия поиска.
- •4. Внешние соединения.
- •Select таблица.Столбец, таблица.Столбец
- •Тема 11: Создание, изменение и удаление последовательностей.
- •Создание последовательности.
- •2. Изменение и удаление последовательности.
- •3. Генерация значений последовательности.
- •Тема 12: Создание, изменение и удаление представлений.
- •Представления. Создание представлений.
- •Изменение и удаление представлений.
- •Представления. Создание представлений.
- •Изменение и удаление представлений.
- •Тема 13: «Индексы»
- •Понятие индекса. Необходимость использования.
- •Создание и удаление индексов.
- •1. Понятие индекса. Необходимость использования.
- •2. Создание и удаление индексов.
- •Тема 14: «Создание отчетов»
- •2. Форматирование number колонок.
- •3. Оформление Отчета пробелами и итоговыми строками.
- •4. Вычисление итоговых строк при изменении значения колонки.
- •5. Определение заголовков.
- •6. Установка размеров страницы
- •7. Сохранение и Печать Результатов Запроса
- •Тема 15: Управление транзакциями
- •Практикум Раздел 3. Реляционная алгебра.
- •Раздел 4. Проектирование реляционных баз данных.
- •Раздел 5. Определение структур данных и обслуживание баз данных.
- •Библиографический список
Использование функций для работы с датами при организации запроса.
Для вывода определенного набора данных в рамках времени и даты используют функции для работы с датами и временем.
Функция |
Назначение |
MONTHS_BETWEEN(date1, date2) |
Определяет число месяцев, разделяющих две даты. Дробная часть результата представляет собой долю месяца. |
ADD_MONTHS(date,n) |
Добавление календарных месяцев к дате. |
NEXT_DAY(date, ‘char’) |
Ближайшая дата, когда наступит заданный день. Аргумент ‘char’ может задавать порядковый номер или название дня недели. |
LAST_DAY(date) |
Определение последнего дня месяца, содержащего заданную дату. |
ROUND(date[, ‘fmt’]) |
Округление до целого числа суток. Если fmt=YEAR, определяет первый день года. |
TRUNC(date[, ‘fmt’]) |
Возвращает первый день месяца, указанного в аргументе date. Если fmt=YEAR, возвращает дату первого дня года. |
SYSDATE() |
Возвращает текущую дату и время. |
Пример 8: Вывод фамилии и количества отработанных недель для служащих отдела 43.
SELECT fam_cotr, ROUND (SYSDATE - start_date)/7,0
FROM Zaniat
WHERE id_otdel =43;
Пример 9: Вывод номера служащего, даты начала работы, количества отработанных месяцев и даты полугодовой аттестации для всех служащих, работающих менее 48 месяцев.
SELECT id_cotr, start_date,
MONTHS_BETWEEN (SYSDATE, start_date) OTRAB_MEC,
ADD_MONTHS (start_date, 6) ATTEST
FROM Zaniat
WHERE MONTHS_BETWEEN(SYSDATE, start_date)<48;
Пример 10: Вывод номера и даты каждого заказа, принятого торговым представителем номера 11. Вывод дат должен производиться в виде 08/05.
SELECT id, to_char(date_prin, ‘MM/YY’) DATA_PRIN
FROM Zakaz
WHERE id_predstav = 11;
Примечание: Функция TO_CHAR предназначена для преобразования типа даты или типа числа в строку символов в соответствии с форматной моделью.
TO_CHAR(date[, ‘форматная модель’]);
TO_CHAR(number[, ‘форматная модель’]);
Пример 11: Вывод даты следующей пятницы, отстоящей на шесть месяцев от даты заказа. Выходная дата должна иметь следующий вид: Friday, March 12 th, 2005-11-07
SELECT TO_CHAR (NEXT_DAY(ADD_MONTHS (date_zakaz,6), ‘FRIDAY’), ‘fmDAY, Month ddth, YYYY’)
FROM Zakaz;
Тема 8: Группировка строк в запросе
Предложение GROUP BY в команде SELECT. Групповые функции.
Группы внутри групп.
Предложение HAVING.
1. Предложение GROUP BY в команде SELECT. Групповые функции.
По умолчанию все строки таблицы рассматриваются как одна группа. Для разбиения таблицы на меньшие группы строк используется предложение GROUP BY команды SELECT.
Синтаксис:
SELECT {столбец, групповая_функция}
FROM Таблица
[WHERE условие]
[GROUP BY выражение_группирования]
[ORDER BY {Столбец, выражение} [ASC|DESC]];
где выражение_группирования определяет столбец, по значениям которого группируются строки.
Для получения сводной информации по каждой группе можно использовать групповые функции:
Функция |
Возвращаемое значение |
AVG([DISTINCT|ALL]n) |
Среднее значение от n, нулевые значения опускаются |
COUNT([ALL]*) |
Число строк, извлекаемых в запросе или подзапросе |
COUNT([DISTINCT|ALL] expr) |
Число строк, для которых expr принимает не пустое значение |
MAX([DISTINCT|ALL] expr) |
Максимальное значение выражения eхрr |
MIN([DISTINCT|ALL] expr) |
Минимальное значение выражения eхрr |
SUM([DISTINCT|ALL] n) |
Сумма значений n |
Если в предложение SELECT включена групповая функция, получить одновременно отдельные результаты можно только в случае, если в предложении GROUP BY задан отдельный столбец. Если список столбцов отсутствует, выдается сообщение об ошибке.
Предложение WHERE позволяет исключить некоторые строки до начала разбиения на группы.
Если в списке SELECT заданы столбцы одновременно с групповыми функциями, их список должен использоваться и в предложении GROUP BY. В предложении GROUP BY нельзя использовать позиционные обозначения или псевдонимы столбцов.
По умолчанию строки сортируются в порядке возрастания в соответствии со списком GROUP BY. Изменить порядок сортировки можно с помощью предложения ORDER BY.
Пример 1: Вывести фамилию и количество преподавателей, работающих в 123 группе (таблиц Prep).
SELECT fam, COUNT(*) as “Количество”
FROM Prep
WHERE grup = 123
GROUP BY fam;
Столбец, заданный в предложении GROUP BY, необязательно должен быть задан в предложении SELECT. С другой стороны, если столбец из предложения GROUP BY входит в список SELECT, результат имеет больше смысла.
Если в одной и той же команде SELECT указаны как отдельные элементы данных, так и групповые функции, но пропущено предложение GROUP BY, описывающее эти отдельные элементы, выдается сообщение об ошибке.
Пример 2:
SELECT id_region, COUNT(name)
FROM Klienti;
*
ERROR at line 1:
ORA-00937: not a single-group group function
(Ошибка в строке 1:
групповая функция не для единственной группы).
Для исправления этой ошибки следует добавить предложение GROUP BY.