![]()
Главная Обратная связь Дисциплины:
Архитектура (936) ![]()
|
Специальные реляционные операторы
Зависимые и примитивные реляционные операторы. Выводы. 7.1. Специальные реляционные операторы 7.1.1. Выборка (ограничение, селекция) Определение 6. Выборкой (ограничением, селекцией) на отношении В простейшем случае условие Синтаксис операции выборки: или Пример 6. Пусть дано отношение
Таблица 9. Отношение A. Результат выборки
Таблица 10. Отношение A WHERE Зарплата<3000. Смысл операции выборки очевиден - выбрать кортежи отношения, удовлетворяющие некоторому условию. Таким образом, операция выборки дает "горизонтальный срез" отношения по некоторому условию. 7.1.2. Проекция Определение 7. Проекцией отношения Синтаксис операции проекции: Замечание. Операция проекции дает "вертикальный срез" отношения, в котором удалены все возникшие при таком срезе дубликаты кортежей. Пример 7. Пусть дано отношение
Таблица 11. Отношение A (Поставщики). Проекция
Таблица 12. Отношение A[Город поставщика]. 7.1.3. Соединение Операция соединения отношений, наряду с операциями выборки и проекции, является одной из наиболее важных реляционных операций. Обычно рассматривается несколько разновидностей операции соединения:
Наиболее важным из этих частных случаев является операция естественного соединения. Все разновидности соединения являются частными случаями общей операции соединения. Общая операция соединения Определение 8. Соединением отношений
Таким образом, операция соединения есть результат последовательного применения операций декартового произведения и выборки. Если в отношениях Тэта-соединение Определение 9. Пусть отношение Это частный случай операции общего соединения. Иногда, для операции Пример 8. Рассмотрим некоторую компанию, в которой хранятся данные о поставщиках и поставляемых деталях. Пусть поставщикам и деталям присвоен некий статус. Пусть бизнес компании организован таким образом, что поставщики имеют право поставлять только те детали, статус которых не выше статуса поставщика (смысл этого может быть в том, что хороший поставщик с высоким статусом может поставлять больше разновидностей деталей, а плохой поставщик с низким статусом может поставлять только ограниченный список деталей, важность которых (статус детали) не очень высока).
Таблица 13. Отношение A (Поставщики).
Таблица 14. Отношение B (Детали).
Ответ на вопрос "какие поставщики имеют право поставлять какие детали?" дает
Таблица 15. Отношение "Какие поставщики поставляют какие детали". Экви-соединение Наиболее важным частным случаем Пример 9. Пусть имеются отношения
Таблица 16. Отношение P (Поставщики).
Таблица 17. Отношение D (Детали).
Таблица 18. Отношение PD (Поставки). Ответ на вопрос, какие детали поставляются поставщиками, дает экви-соединение Обычно, такой сложной формой записи не пользуются. Но как бы то ни было, в результате имеем отношение:
Таблица 19. Отношение "Какие детали поставляются какими поставщиками". Недостатком экви-соединения является то, что если соединение происходит по атрибутам с одинаковыми наименованиями (а так чаще всего и происходит!), то в результатирующем отношении появляется два атрибута с одинаковыми значениями. В нашем примере атрибуты PNUM1 и PNUM2 содержат дублирующие данные. Избавиться от этого недостатка можно, взяв проекцию по всем атрибутам, кроме одного из дублирующих. Именно так действует естественное соединение. Естественное соединение Определение 10. Пусть даны отношения Тогда естественным соединением отношений Естественное соединение настолько важно, что для него используют специальный синтаксис: Замечание. В синтаксисе естественного соединения не указываются, по каким атрибутам производится соединение. Естественное соединение производится по всем одинаковым атрибутам. Замечание. Естественное соединение эквивалентно следующей последовательности реляционных операций:
Замечание. Можно выполнять последовательное естественное соединение нескольких отношений. Нетрудно проверить, что естественное соединение (как, впрочем, и соединение общего вида) обладает свойством ассоциативности, т.е. поэтому такие соединения можно записывать, опуская скобки: Пример 10. В предыдущем примере ответ на вопрос "какие детали поставляются поставщиками", более просто записывается в виде естественного соединения трех отношений
Таблица 20. Отношение P JOIN PD JOIN D. 7.1.4. Деление Определение 11. Пусть даны отношения Отношение Синтаксис операции деления: A DEVIDEBY B Замечание. Типичные запросы, реализуемые с помощью операции деления, обычно в своей формулировке имеют слово "все" - "какие поставщики поставляют все детали?". Пример 11. В примере с поставщиками, деталями и поставками ответим на вопрос, "какие поставщики поставляют все детали?". В качестве делимого возьмем проекцию
Таблица 21. Проекция X=PD[PNUM,DNUM]. В качестве делителя возьмем проекцию
Таблица 22. Проекция Y=D[DNUM]. Деление
Таблица 23. Отношение X DEVIDEBY Y. Оказалось, что только поставщик с номером 1 поставляет все детали. 7.2. Реляционные операторы 7.2.1. Зависимые реляционные операторы Как было сказано в обзоре реляционной алгебры, не все операторы реляционной алгебры являются независимыми - некоторые из них выражаются через другие реляционные операторы. Оператор соединения Оператор соединения определяется через операторы декартового произведения и выборки. Для оператора естественного соединения добавляется оператор проекции. Оператор пересечения Оператор пересечения выражается через вычитание следующим образом: Оператор деления Оператор деления выражается через операторы вычитания, декартового произведения и проекции следующим образом: Таким образом показано, что операторы соединения, пересечения и деления можно выразить через другие реляционные операторы, т.е. эти операторы не являются примитивными. 7.2.2. Примитивные реляционные операторы Оставшиеся реляционные операторы (объединение, вычитание, декартово произведение, выборка, проекция) являются примитивными операторами - их нельзя выразить друг через друга. Оператор декартового произведения Оператор декартового произведения - это единственный оператор, увеличивающий количество атрибутов, поэтому его нельзя выразить через объединение, вычитание, выборку, проекцию. Оператор проекции Оператор проекции - единственный оператор, уменьшающий количество атрибутов, поэтому его нельзя выразить через объединение, вычитание, декартово произведение, выборку. Оператор выборки Оператор выборки - единственный оператор, позволяющий проводить сравнения по атрибутам отношения, поэтому его нельзя выразить через объединение, вычитание, декартово произведение, проекцию. Операторы объединения и вычитания Доказательство примитивности операторов объединения и вычитания более сложны и мы их здесь не приводим. Запросы, невыразимые средствами реляционной алгебры Несмотря на мощь языка реляционной алгебры, имеется ряд типов запросов, которые принципиально нельзя выразить только при помощи операторов реляционной алгебры. Это вовсе не означает, что ответы на эти запросы нельзя получить вообще. Просто, для получения ответов на подобные запросы приходится применять процедурные расширения реляционных языков. 7.3. Выводы Доступ к реляционным данным возможен при помощи операторов реляционной алгебры. Реляционная алгебра представляет собой набор операторов, использующих отношения в качестве аргументов, и возвращающие отношения в качестве результата. Реляционная алгебра замкнута таким образом, что результаты одних реляционных выражений можно использовать в других выражениях. Традиционно определяют восемь реляционных операторов, объединенных в две группы. Теоретико-множественные операторы: объединение, пересечение, вычитание, декартово произведение. Специальные реляционные операторы: выборка, проекция, соединение, деление. Для выполнения некоторых реляционных операторов требуется, чтобы отношения были совместимы по типу. Не все операторы реляционной алгебры являются независимыми - некоторые из них выражаются через другие реляционные операторы. Операторы соединения, пересечения и деления можно выразить через другие реляционные операторы, т.е. эти операторы не являются примитивными. Оставшиеся реляционные операторы (объединение, вычитание, декартово произведение, выборка, проекция) являются примитивными операторами - их нельзя выразить друг через друга. Имеется несколько типов запросов, которые нельзя выразить средствами реляционной алгебры. (К ним относятся запросы, требующие дать в ответе список атрибутов, удовлетворяющих определенным условиям, построение транзитивного замыкания отношений, построение кросс-таблиц. Для получения ответов на подобные запросы приходится использовать процедурные расширения реляционных языков) Лекция 8. Реляционное исчисление.
![]() |