Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

2584

.pdf
Скачиваний:
1
Добавлен:
15.11.2022
Размер:
1.88 Mб
Скачать

60

Выборка (или ограничение)

(R) –

предикат

Операция выборки работает с одним отношением R и определяет результирующее отношение, которое содержит только те кортежи (строки) отношения R, которые удовлетворяют заданному условию (предикату).

Пример. Составить список сотрудников с окладом, превышающим 3000 рублей.

(«Персонал») оклад>3000

Результатом операции будет отношение

Таблица 12

Личн

Имя, отч.

Фамил

Адрес

Телефо

Долж-

Пол

Дата

Зарплата

№ страх

. №

 

ия

 

н

ность

 

рожд.

 

 

отделения

45

Юрий

Иванов

Воронеж,

56-87-

менеджер

м

21.89.5

15000

4567990

В5

 

Иванович

 

Пр-т

88

 

 

6

 

 

 

 

 

 

Революции,

 

 

 

 

 

 

 

 

 

 

д. 8, кв. 23

 

 

 

 

 

 

 

01

Николай

Петров

Воронеж,

56-89-

менеджер

м

08.11.6

3500

4637892

В5

 

Николаевич

 

ул. Ленина,

56

 

 

8

 

 

 

 

 

 

д.78, кв.13

 

 

 

 

 

 

 

60

61

 

Проекция

П

(R) -

атр1, …атр. n

Операция проекции работает с одним отношением R и определяет новое отношение, содержащее вертикальное подмножество отношений R , создаваемое посредством извлечения значений, указанных атрибутов и исключения из результата строк - дубликатов.

______________________________________

Пример.

Создать ведомость зарплаты всех сотрудников компании с указанием следующих атрибутов: Фамилия, Имя, Зарплата.

П (Персонал) фам, имя, з/п

В этом примере операция проекции определяет новое отношение, которое будет содержать только атрибуты Фамилия, Имя, Зарплата отношения Персонал», размещенные в указанном порядке.

Таблица 13

Имя, отч.

Фамилия

Зарплата

Юрий Иванович

Иванов

15000

Ольга Сергеевна

Дашкова

2400

Ирина Алекссевна

Берг

1470

Сергей Андреевич

Лосев

2100

Николай Николаевич

Петров

3500

Иван Петрович

Смирнов

2300

61

62

Декартово произведение

RxS – операция декартового произведения определяет новое отношение, которое является результатом конкатенации (сцепления) каждого кортежа из отношения R с каждым кортежем из отношения S.

Операторы выборки и проекции извлекают информацию только из одного отношения. Очевидно, возможно возникновение таких ситуаций, когда нужна некоторая комбинация данных из нескольких отношений. Оператор декартового произведения умножает два отношения, что в результате приводит к созданию другого отношения, состоящего из всех возможных пар кортежей обоих отношений.

Пример.

Создать список всех арендаторов, которые осматривали объекты недвижимости. С указанием сделанных ими комментариев.

«Арендатор») ) Х

(«Осмотр») )

личн.№, ФИО

№аренд.,№ объекта, коммент.

Здесь перемножаются все кортежи двух отношений: первый – список арендаторов, второй – осмотр.

62

Результатом будет отношение

Таблица 14

 

Личн.

ФИО

Личн.№

Комментарии

 

 

аренд

объекта

 

 

01

Сидоров Ю.К,

01

01

Нет балкона

 

01

Сидоров Ю.К,

01

09

Грязный подъезд

 

01

Сидоров Ю.К,

04

11

Требуется ремон

 

04

Рачков П.Л.

01

01

Нет балкона

 

04

Рачков П.Л.

01

09

Грязный подъезд

 

04

Рачков П.Л.

04

11

Требуется ремон

 

07

Плетнева Р.С.

01

01

Нет балкона

63

07

Плетнева Р.С.

01

09

Грязный подъезд

07

Плетнева Р.С.

04

11

Требуется ремон

 

 

12

Воронецева Н.Н.

01

01

Нет балкона

 

12

Воронецева Н.Н.

01

09

Грязный подъезд

 

12

Воронецева Н.Н.

04

11

Требуется ремон

В результате произведения получается отношение, которое содержит больше информации, чем необходимо. Для получения искомого списка необходимо для этого отношения произвести операцию выборки с извлечением тех кортежей, для которых выполняется условие: данный арендатор осматривал данную недвижимость.

Результатом этой операции будет являться следующее отношение

63

Таблица 15

Личн.

ФИО

Личн.№

Комментарии

 

аренд

объекта

 

01

Сидоров Ю.К,

01

01

Нет балкона

01

Сидоров Ю.К,

01

09

Грязный подъезд

04

Рачков П.Л.

04

11

Требуется ремон

Как мы увидим позднее, комбинация декартового произведения и выборки может быть сведена к одной операции соединения.

64

Объединение.

R U S – объединение отношений R и S с кортежами I и J соответственно можно получить в результате их конкатенации с образованием одного отношения с максимальным количеством кортежей (I + J), если кортежи-дубликаты исключены. При этом отношения R и S должны быть совместимы по объединению.

Объединение отношений возможно только в том случае, если совпадают их схемы, т.е. если они имеют одинаковое количество атрибутов с совпадающими доменами. Иначе говоря, отношения должны быть совместимы по объединению. Отметим, что в некоторых случаях для получения двух совместимых по объединению отношений может быть использована операция проекции.

64

Пример.

Создать список всех городов, в которых имеется отделение компании или объект недвижимости

«Отделение») ) U

(«Объекты») )

город

 

город

65

Результатом объединения будет отношение

Таблица 16

Город

Воронеж

Липецк

Тамбов

Курск

Ст.Оскол

Разность

R – S - разность двух отношений R и S состоит из кортежей, которые имеются в отношении R, но отсутствуют в отношении S. Причем отношения R и S должны быть совместимы по объединению.

65

Пример.

Создать список всех городов, в которых есть отделения компании, но нет объектов недвижимости, сдаваемых в аренду

«Отделение») ) - (П

(«Объекты») )

город

 

город

66

Результатом разности будет отношение

Таблица 17

Город

Липецк

Тамбов

Ст.Оскол

Операции соединения.

Как правило, пользователя интересует лишь некоторая часть всех комбинаций кортежей декартового произведения, которая удовлетворяет заданному условию. Поэтому вместо декартового произведения обычно используется одна из самых важных операций реляционной алгебры – операция соединения. В результате этой операции создается новое отношение. Операция соединения является производной от операции декартового произведения двух операндов – отношений тех кортежей, которые удовлетворяют условию, указанному в предикате соединения в качестве формулы выборки. С точки зрения эффективной реализации в

66

67

реляционных СУБД, эта операция является одной из самых трудных и часто оказывается одной из основных причин, вызывающих проблемы с производительностью, свойственной всем реляционным системам.

Существует несколько типов операций соединения:

Тета-соединения ( -join)

Соединение по эквивалентности (equi-join), которое является частным видом тетасоединения.

Естественное соединение (natural-join) Внешнее соединение (outer-join) Полусоединение (semi - join)

 

Тета-соединение

R

S

 

F

Операция тета-соединения определяет отношение, которое содержит кортежи из декартового произведения отношений R и S, удовлетворяющие предикату F. Предикат F имеет вид R.a1 S.b1, где вместо может быть указан один из операндов сравнения (<, >, <=, >=, = или –=).

67

Так же как и в случае с декартовым произведением, степенью тета-соединения называется сумма степеней операндов-отношений R и S. Если предикат F содержит только оператор равенства, то соединение называется соединением по эквивалентности.

Пример (операция соединения по эквивалентности).

Создать список всех арендаторов, которые осматривали объект недвижимости, с указанием их имен и сделанных ими комментариев.

68

«Арендатор») )

(«Осмотр») )

личн.№, ФИО

Персонал.личн. №= Осмотр.личн.№

№аренд.,№ объекта, коммент.

 

аренд.

 

аренд.

 

Ранее для получения этого списка использовались операции декартового произведения и выборки. однако тот же самый результат можно получить с помощью операции соединения по эквивалентности.

Результатом этой операции будет являться следующее отношение

Таблица 18

Личн. №

ФИО

Личн.№

Комментарии

аренд.

 

аренд

объекта

 

 

 

 

 

 

01

Сидоров Ю.К,

01

01

Нет балкона

01

Сидоров Ю.К,

01

09

Грязный

 

 

 

 

подъезд

04

Рачков П.Л.

04

11

Требуется

 

 

 

 

ремон

68

69

Естественное соединение

R S Естественным соединением называется соединение по эквивалентности двух отношений R и S, выполненное по всем общим атрибутам X , из результатов которого исключается по одному экземпляру каждого общего атрибута.

Степенью естественного соединения называется сумма операндов-отношений R и S минус количество атрибутов x.

Пример.

Создать список всех арендаторов, которые осматривали объекты недвижимости, с указанием их имен и сделанных ими комментариев.

В предыдущем примере для составления этого списка использовалось соединение по эквивалентности, но в нем присутствовало два одинаковых атрибута «личный № арендатора».

Для удаления одного из этих атрибутов можно воспользоваться операцией естественного соединения.

«Арендатор») )

(«Осмотр») )

 

личн.№, ФИО

№аренд.,№ объекта, коммент.

Внешнее соединение

Зачастую при соединении двух отношений кортеж из одного отношения не находит соответствующего кортежа в другом отношении. Иначе говоря, в столбцах соединения оказываются несовпадающие значения. Может потребоваться, чтобы строка из одного

69

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]