Реляционная алгебра: операции над данными, свойства и связь с SQL — различия между версиями
Imka239 (обсуждение | вклад) (→Агрегирование) |
Imka239 (обсуждение | вклад) (→Агрегирование) |
||
Строка 35: | Строка 35: | ||
{{Определение | {{Определение | ||
|definition= | |definition= | ||
− | '''Агрегирование''' позволяет выполнить функцию на нескольних кортежах сразу. Допустим есть Q - агрегируемый атрибут и A - | + | '''Агрегирование''' позволяет выполнить функцию на нескольних кортежах сразу. Допустим есть Q - агрегируемый атрибут и A - сохраняемые атрибуты. Сохраним в один набор все кортежи с равными значениями сохранямых атрибутов. Затем применим внутри каждого набора некоторую функцию. |
+ | }} | ||
К типичным разновидностям относятся `SUM`, `COUNT`, `AVG`, `MAX`, `MIN`, `ALL`, `ANY`. | К типичным разновидностям относятся `SUM`, `COUNT`, `AVG`, `MAX`, `MIN`, `ALL`, `ANY`. | ||
Пример операции `SUM` над отношением | Пример операции `SUM` над отношением |
Версия 16:42, 19 декабря 2021
Содержание
Операции над данными
Расширение
Определение: |
Операция расширения позволяет добавить вычисляемый атрибут. Она принимает отношение и возвращает другое, идентичное заданному, добавляя к нему дополнительный атрибут, полученный в результате вычисления произвольных скалярных функций от значений атрибутов. |
Пример: отношение R со значением веса в фунтах
Id | Weight |
---|---|
1 | 12.0 |
2 | 17.0 |
Примером будет
— мы добавим значение веса в граммах:Id | Weight | GMWT |
---|---|---|
1 | 12.0 | 5448.0 |
2 | 17.0 | 7718.0 |
Агрегирование
Определение: |
Агрегирование позволяет выполнить функцию на нескольних кортежах сразу. Допустим есть Q - агрегируемый атрибут и A - сохраняемые атрибуты. Сохраним в один набор все кортежи с равными значениями сохранямых атрибутов. Затем применим внутри каждого набора некоторую функцию. |
К типичным разновидностям относятся `SUM`, `COUNT`, `AVG`, `MAX`, `MIN`, `ALL`, `ANY`. Пример операции `SUM` над отношением
Supplier | Price | Items |
---|---|---|
1 | 1 | 4 |
1 | 2 | 5 |
2 | 3 | 6 |
Посчитаем
, получаем:Supplier | Total |
---|---|
1 | 14 |
2 | 18 |
Ещё один хороший пример - сумма по пустому множеству аттрибутов. Посчитаем
от того же отношения и получимTotal |
---|
32 |
Свойства реляционной алгебры
Свойства операций
Определение: |
Идемпотентность — свойство при повторном применении операции давать тот же результат. Примеры: унарные и , бинарные , , и др. значки. |
Определение: |
Коммутативность — свойство переместительностию ( Пример: , , . | ).
Определение: |
Ассоциативность — свойство Пример: , , . | .
Базис операций
- Унарные операции (projection, filter и переименование)
- Объединение и разность
- Декартово произведение
- Операции над данными (расширение и агрегирование)
Остальные привычные операции выразимы из этого базиса, например
Ограничения реляционной алгебры
- Не все операции представимы (например, транзитивное замыкание)
- Следует, что РА не эквивалентна машине Тьюринга
- Эквивалентность выражений алгоритмически неразрешима
Зачем?
- Внутри БД для оптимизации запроса и плана выполнения
- Для запросов, невыразимых в SQL непосредственно
Реляционная алгебра и SQL
Унарные операции
Проекция
select distinctfrom R select from R -- с повторениями
Фильтрация
select * from R where Condition
Переименование
select ..., a as b, ... from R
Операции над множествами
Объединение
select * from R1 union select * from R2 select * from R1 union all select * from R2 -- с повторениями
Пересечение
select * from R1 intersect select * from R2 select * from R1 intersect all select * from R2 -- с повторениями
Разность
select * from R1 except all select * from R2 select * from R1 except all select * from R2 -- с повторениями
Операции над данными
Расширение
select *, expr as A from R
Агрегирование
select A, func(Q) as Q from R group by A select count(*)... -- подсчёт всех select count(distinct *)... -- подсчёт различных select count(q)... -- подсчёт не null ... having Condition -- фильтрация после агрегации ... order by Attrs -- сортировка
Соединения
Полное
select * from R1 cross join R2 select * from R1, R2
Естественное
select * from R1 natural join R2 select * from R1 inner join R2 using (A) select * from R1 inner join R2 on R1.A = R2.A
Внешние
select * from R1 [full] outer join R2 onselect * from R1 left [join] R2 on select * from R1 right [join] R2 on
Структура SQL-запроса
SQL-запрос иммеет вид
select ... as ..., ... as ... --и from xxx join on ... -- ... xxx join on ... -- where ... --
Примеры
- Пусть дана таблица `Persons (Id, Name, Birthday, MotherId, FatherId)` и требуется получить дни рождения родителей - `(Name, FatherBirthday, MotherBirthday)`
select p.Name as Name f.Birthday as FatherBirthday m.Birthday as MotherBirthday from Persons p inner join Persons f on p.FatherId = f.id inner join Persons m on p.MotherId = m.id
- Подзапросы: например, найти людей, у которых родители родились в один день `Name`
select p.Name as Name from (предыдущий запрос текстом) where p.MotherBirthday = p.FatherBirthday
Литература
- Дейт К. Введение в системы баз данных
- Уидом Д., Ульман Д. Основы реляционных баз данных