Введение в базы данных Ограничения, присущие файловым системам



Download 0,92 Mb.
bet27/44
Sana08.06.2022
Hajmi0,92 Mb.
#642978
TuriЛекция
1   ...   23   24   25   26   27   28   29   30   ...   44
Bog'liq
Лекция 1

Соединением отношений и по условию z называется отношение (A TIMES B) WHERE z, где z представляет собой логическое выражение, в которое могут входить атрибуты отношений и и (или) скалярные выражения.
Таким образом, операция соединения есть результат последовательного применения операций декартового произведения и выборки. Если в отношениях и имеются атрибуты с одинаковыми наименованиями, то перед выполнением соединения такие атрибуты необходимо переименовать. Чтобы сделать различными.
Пример. Пусть даны два отношения A и B с информацией о поставщиках и деталях.
Таблица 6.13 - Отношение A (Поставщики)

Номер поставщика

Наименование поставщика

1

Иванов

2

Петров

3

Сидоров

Таблица 6.14 - Отношение B (Детали)

Номер детали

Наименование детали

1

Болт

2

Гайка

3

Винт

Декартово произведение отношений и будет иметь вид.
Таблица 6.15 - Отношение A TIMES B

Номер поставщика

Наименование поставщика

Номер детали

Наименование детали

1

Иванов

1

Болт

1

Иванов

2

Гайка

1

Иванов

3

Винт

2

Петров

1

Болт

2

Петров

2

Гайка

2

Петров

3

Винт

3

Сидоров

1

Болт

3

Сидоров

2

Гайка

3

Сидоров

3

Винт

Если к нему приложить условие «Какие поставщики поставляют болты» то есть «Какие поставщики поставляют детали с номером 1», то в результате получим отношение.
Таблица 6.16 - Отношение A TIMES B WHERE Номер детали = 1

Номер поставщика

Наименование поставщика

Номер детали

Наименование детали

1

Иванов

1

Болт

2

Петров

1

Болт

3

Сидоров

1

Болт

На практике используются несколько разновидностей операции соединения, отличающиеся немного друг от друга:
 -соединение (тэта-соединение);
 экви-соединение (эквивалентное соединение, частный случай тэта-соединения);
 естественное соединение.

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


Пусть отношение содержит атрибут X, отношение содержит атрибут Y, а  - один из операторов сравнения ( и т.д.). Тогда -соединением отношения по атрибуту с отношением по атрибуту называют отношение (A TIMES B) WHERE XY.
Иногда для операции -соединения применяют следующий, более короткий синтаксис: A [XY] B.
Пример. Рассмотрим некоторую БД, в которой хранятся данные о поставщиках и поставляемых деталях. Поставщикам и деталям присвоен некий статус. Бизнес организован таким образом, что поставщики имеют право поставлять только те детали, статус которых не выше статуса поставщика (смысл этого может быть в том, что поставщик с высоким статусом может поставлять больше разновидностей деталей, а плохой поставщик с низким статусом может поставлять только ограниченный список деталей, важность которых (статус детали) не очень высока).
Таблица 6.17 - Отношение A (Поставщики)

Номер поставщика

Наименование поставщика

Статус поставщика (X)

1

Иванов

4

2

Петров

1

3

Сидоров

2

Таблица 6.18 - Отношение B (Детали)

Номер детали

Наименование детали

Статус детали (Y)

1

Болт

3

2

Гайка

2

3

Винт

1

Ответ на вопрос "какие поставщики имеют право поставлять какие детали?" дает -соединение A [X>=Y].
Таблица 6.19 - Отношение A [X>=Y] B

Номер поставщика

Наименование поставщика

X (Статус поставщика)

Номер детали

Наименование детали

Y (Статус детали)

1

Иванов

4

1

Болт

3

1

Иванов

4

2

Гайка

2

1

Иванов

4

3

Винт

1

2

Петров

1

3

Винт

1

3

Сидоров

2

2

Гайка

2

3

Сидоров

2

3

Винт

1

Экви-соединение. Наиболее важным частным случаем -соединения является случай, когда  есть просто равенство. То есть если условие соединения имеет вид (X = Y), где X и Y - атрибуты разных операндов соединения.


Синтаксис экви-соединенияA[X=Y]B.
Таблица 6.20 - Отношение A (Поставщики)

Номер поставщика

Наименование поставщика

Статус изделия (X)

1

Иванов

4

2

Петров

1

3

Сидоров

2

Таблица 6.21 - Отношение B (Детали)

Номер детали

Наименование детали

Статус изделия (Y)

1

Болт

3

2

Гайка

2

3

Винт

1

Таблица 6.22 - Отношение A [X=Y] B

Номер поставщика

Наименование поставщика

X (Статус изделия)

Номер детали

Наименование детали

Y (Статус изделия_1

3

Сидоров

2

2

Гайка

2

Недостатком экви-соединения является то, что если соединение происходит по атрибутам с одинаковыми наименованиями (а так чаще всего и происходит), то в результирующем отношении появляется два атрибута с одинаковыми значениями. В нашем примере атрибуты Статус изделия и Статус изделия_1 содержат дублирующие данные. Избавиться от этого недостатка можно, взяв проекцию по всем атрибутам, кроме одного из дублирующих. Именно так действует естественное соединение.

Естественное соединение. Операция естественного соединения применяется к паре отношений A и B, обладающих (возможно составным) общим атрибутом c (т.е. атрибутом с одним и тем же именем и определенным на одном и том же домене).


Пусть даны отношения A(A1,A2,...,An,X1,X2,...Xn) и B(X1,X2,...Xn,B1,B2,. ..,Bn), имеющие одинаковые атрибуты X1,X2,...Xn (т.е. атрибуты с одинаковыми именами и определенные на одинаковых доменах).
Тогда естественным соединением отношений и называется отношение с заголовком (A1,A2,...,An,X1,X2,...Xn, B1,B2,...,Bm) и телом, содержащим множество строк (кортежей) (a1,a2,...,an,x1,x2,...,xn,b1,), таких, что (a1,a2,...,an,x1,x2,...,xn)  и (x1,x2,...,xn,,b1. b2.. . . b)  B.
Словами это можно попытаться представить так: <строки> из отношения A <сцепляются> с теми <строками> отношения B, для которых значения одноименных атрибутов совпадают. Естественно, что совпадающие атрибуты включаются в результирующее отношение в единственном экземпляре.
Естественное соединение настолько важно, что для него используют специальный синтаксис: JOIN B.
В синтаксисе естественного соединения не указываются, по каким атрибутам производится соединение. Естественное соединение производится по всем одинаковым атрибутам.
Можно выполнять последовательное естественное соединение нескольких отношений. Естественное соединение (как, впрочем, и соединение общего вида) обладает свойством ассоциативности, т.е.:
(A JOIN B) JOIN C = A JOIN (B JOIN C)
поэтому такие соединения можно записывать, опуская скобки:
A JOIN B JOIN C.
Пример. Пусть имеются отношения P, и PD, хранящие информацию о поставщиках, деталях и поставках соответственно (для удобства введем краткие наименования атрибутов).
Таблица 6.23 - Отношение P (Поставщики)

Номер поставщика (PNUM)

Наименование поставщика (PNAME)

1

Иванов

2

Петров

3

Сидоров

Таблица 6.24 - Отношение D (Детали)

Номер детали (DNUM)

Наименование детали (DNAME)

1

Болт

2

Гайка

3

Винт

Таблица 6.25 - Отношение PD (Поставки)

Номер поставщика (PNUM)

Номер детали (DNUM)

Поставляемое количество VOLUME

1

1

100

1

2

200

1

3

300

2

1

150

2

2

250

3

1

1000

Ответ на вопрос "какие детали поставляются поставщиками", можно записать в виде естественного соединения трех отношений P JOIN PD JOIN D).
Таблица 6.26 - Отношение P JOIN PD JOIN D

Номер поставщика
PNUM

Наименование поставщика
PNAME

Номер детали
DNUM

Наименование детали
DNAME

Поставляемое количество
VOLUME

1

Иванов

1

Болт

100

1

Иванов

2

Гайка

200

1

Иванов

3

Винт

300

2

Петров

1

Болт

150

2

Петров

2

Гайка

250

3

Сидоров

1

Болт

1000

Деление (division) – это бинарная операция над разносхемными отношениями A и B. Пусть отношение A содержит атрибуты { X1,X2,…,Xn,Y1,Y2,…,Ym}, а отношение B – атрибуты {Y1,Y2,…,Ym }, причем атрибуты Y1,Y2,…,Ym - общие для двух отношений Результирующее отношение содержит атрибуты {X1,X2,…,Xn}. Кортеж включается в результирующее отношение, если его декартово произведение с отношением B входит в A.
Либо:
Делением отношений  A на называется отношение с заголовком (X1,X2,…,Xn) и телом, содержащим множество кортежей (x1,x2,…,xn), таких, что для всех кортежей y1,y2,…,ym)  B в отношении  A найдется кортеж (x1,x2,…,xn,y1,y2,…,ym).
Отношение A выступает в роли делимого, отношение выступает в роли делителя. Деление отношений аналогично делению чисел с остатком.
Синтаксис операции деления: DEVIDBY B
Пример. В примере с поставщиками, деталями и поставками ответим на вопрос, "какие поставщики поставляют все детали?".
В качестве делимого возьмем проекцию X= PD [PNUM, DNUM], содержащую номера поставщиков и номера поставляемых ими деталей.
Таблица 6.27 - Проекция X=PD[PNUM,DNUM]

Номер поставщика PNUM

Номер детали DNUM

1

1

1

2

1

3

2

1

2

2

3

1

В качестве делителя возьмем проекцию Y=D[DNUM], содержащую список номеров всех деталей (не обязательно поставляемых кем-либо).
Таблица 6.28 - Проекция Y=D[DNUM]

Номер детали DNUM

1

2

3

Деление X DEVIDEBY Y дает список номеров поставщиков, поставляющих все детали.
Таблица 6.29 - Отношение X DEVIDEBY Y

Номер поставщика PNUM

1

Оказалось, что только поставщик с номером 1 поставляет все детали.

Download 0,92 Mb.

Do'stlaringiz bilan baham:
1   ...   23   24   25   26   27   28   29   30   ...   44




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish