wiki:Normalization

Нормализација

Функциски зависности

R(id_admin, ime_admin, prezime_admin, email_admin, password_admin, id_nastavnik, ime_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)


Множество функциски зависности:

FD = {
id_admin → (ime_admin, prezime_admin, email_admin, password_admin),
email_admin → id_admin,
id_nastavnik → (ime_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik),
email_nastavnik → id_nastavnik,
id_ucenik → (ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik),
email_ucenik → id_ucenik,
id_kvalifikacija → dokument_kvalifikacija,
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → (vreme_pocetok_cas, tema_cas),
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → (id_plakjanja, id_ucenik, plateno),
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → (cena_po_cas, broj_casovi_po_dogovor)
}


Со примена на неколку чекори (Армстронгова аксиома за декомпозиција, отфрлање екстра атрибути и редундантни зависности), може да се добие следната канонична покривка (сите ф.з. се во нов ред):

Fc = {
id_admin → ime_admin,
id_admin → prezime_admin,
id_admin → email_admin,
id_admin → password_admin,
email_admin → id_admin,
id_nastavnik → ime_nastavnik,
id_nastavnik → prezime_nastavnik,
id_nastavnik → opis_nastavnik,
id_nastavnik → email_nastavnik,
id_nastavnik → password_nastavnik,
id_nastavnik → telefonski_broj_nastavnik,
email_nastavnik → id_nastavnik,
id_ucenik → ime_ucenik,
id_ucenik → prezime_ucenik,
id_ucenik → opis_ucenik,
id_ucenik → email_ucenik,
id_ucenik → password_ucenik,
id_ucenik → telefonski_broj_ucenik,
email_ucenik → id_ucenik,
id_kvalifikacija → dokument_kvalifikacija,
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}

Нормална форма

Врз основа на горенаведените функциски зависности, нашиот актуелен дизајн се наоѓа во 1НФ. Ако погледнеме еден од кандидат клучевите, на пример {id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_slusanje}, ќе забележиме дека подмножество од тој кандидат клуч покажува кон непримарен атрибут, односно постои парцијална зависност (id_admin, што претставува подможество од кандидат клучот, ги определува непримарните атрибути како ime_admin, prezime_admin, email_admin). Ваквиот тип на зависности е нарушување за повисоките нормални форми и според тоа доаѓаме до заклучок дека R е во 1НФ.

Декомпозиција до највисока можна нормална форма

При определување на кандидат клучевите, тргнуваме од најтривијалниот суперклуч составен од сите атрибути, чиј затворач ги содржи сите атрибути.

id_admin, ime_admin, prezime_admin, email_admin, password_admin, id_nastavnik, ime_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet+={id_admin, ime_admin, prezime_admin, email_admin, password_admin, id_nastavnik, ime_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet}


Постепено редуцираме и добиваме еден кандидат клуч:

id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje+={id_admin, ime_admin, prezime_admin, email_admin, password_admin, id_nastavnik, ime_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet}

Примарни атрибути: id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje

Треба да се направи проверка дали има уште кандидат клучеви. Поради трите ф.з. ime_predmet → id_predmet; email_admin → id_admin; email_nastavnik → id_nastavnik, согледуваме дека постојат уште кандидат клучеви бидејќи десната страна од овие ф.з. е примарен атрибут.
Заменуваме, ја повторуваме истата постапка со редуцирањето на атрибути и добиваме уште неколку кандидат клучеви:

  • id_admin, id_nastavnik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • email_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • id_admin, email_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • email_admin, email_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • id_admin, email_nastavnik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • email_admin, id_nastavnik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje
  • email_admin, email_nastavnik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje

Вкупно 23 кандидат клучеви, односно 8.
Од нив избираме еден за примарен клуч. Најоптимално во пракса би било за примарен клуч да биде избран клуч кој ќе овозможи побрзо пребарување (пр. составен од атрибути кои се цели броеви, наместо стрингови) и според тоа за примарен клуч го избираме клучот
id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje.

Во моментот има неколку ф.з. кои прават проблем. Тие се парцијални зависности (вистинско подмножество од к.к. определува непримарен атрибут) и со тоа е нарушена 2НФ. Да претпоставиме дека прва што прави проблем е ф.з. id_nastavnik → ime_nastavnik.

Првобитната релација R која е составена од сите атрибути, ја декомпонираме на R1 и R2. Дел од R1 мора да биде id_nastavnik, заедно со сите атрибути кои тој ги определува, додека пак останатите атрибути одат во R2 (со тоа што за да може да се направи спојување без загуба, мора да има заеднички атрибут со R1, а тој атрибут би бил id_nastavnik).


R1(id_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik)

F1 = {
id_nastavnik → ime_nastavnik,
id_nastavnik → prezime_nastavnik,
id_nastavnik → opis_nastavnik,
id_nastavnik → email_nastavnik,
id_nastavnik → password_nastavnik,
id_nastavnik → telefonski_broj_nastavnik,
email_nastavnik → id_nastavnik
}

Кандидат клучеви: id_nastavnik, email_nastavnik.
Примарни атрибути: id_nastavnik, email_nastavnik.

R1 се наоѓа во BCNF, бидејќи од секоја ф.з. во F1, левата страна е суперклуч, и понатаму не ја декомпонираме.


R2(id_admin, ime_admin, prezime_admin, email_admin, password_admin, id_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F2 = {
id_admin → ime_admin,
id_admin → prezime_admin,
id_admin → email_admin,
id_admin → password_admin,
email_admin → id_admin,
id_ucenik → ime_ucenik,
id_ucenik → prezime_ucenik,
id_ucenik → opis_ucenik,
id_ucenik → email_ucenik,
id_ucenik → password_ucenik,
id_ucenik → telefonski_broj_ucenik,
email_ucenik → id_ucenik,
id_kvalifikacija → dokument_kvalifikacija,
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}

R2 се' уште е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_admin → ime_admin. id_admin ќе го ставиме во посебна релација R3, заедно со атрибутите кои тој ги определува. Се' останато оди во R4, заедно со id_admin кој е заеднички атрибут, за да се направи спојување без загуба на информации.


R3(id_admin, ime_admin, prezime_admin, email_admin, password_admin)
F3 = {
id_admin → ime_admin,
id_admin → prezime_admin,
id_admin → email_admin,
id_admin → password_admin,
email_admin → id_admin
}
Кандидат клучеви: id_admin, email_admin.
Примарни атрибути: id_admin, email_admin.
R3 се наоѓа во BCNF, бидејќи од секоја ф.з. во F3, левата страна е суперклуч.


R4(id_admin, id_nastavnik, id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet) F4 = {
id_ucenik → ime_ucenik,
id_ucenik → prezime_ucenik,
id_ucenik → opis_ucenik,
id_ucenik → email_ucenik,
id_ucenik → password_ucenik,
id_ucenik → telefonski_broj_ucenik,
email_ucenik → id_ucenik,
id_kvalifikacija → dokument_kvalifikacija,
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}

R4 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_ucenik → ime_ucenik.
id_ucenik ќе го ставиме во посебна релација R5, заедно со атрибутите кои тој ги определува. Останатото во R6.


R5(id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik)
F5 = {
id_ucenik → ime_ucenik,
id_ucenik → prezime_ucenik,
id_ucenik → opis_ucenik,
id_ucenik → email_ucenik,
id_ucenik → password_ucenik,
id_ucenik → telefonski_broj_ucenik,
} Кандидат клуч: id_ucenik.
Примарни атрибути: id_ucenik.
R5 се наоѓа во BCNF, бидејќи од секоја ф.з. во F5, левата страна е суперклуч. Оваа релација понатаму не ја декомпонираме.


Да го разгледаме тоа што ни остана во R6. R6(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, dokument_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F6 = {
id_kvalifikacija → dokument_kvalifikacija,
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor }
Кандидат клучеви: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje);
(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje)
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje, ime_predmet.
R6 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_kvalifikacija → dokument_kvalifikacija.
id_kvalifikacija ќе го ставиме во посебна релација R7, заедно со атрибутите кои тој ги определува. Останатото во R8.


R7(id_kvalifikacija, dokument_kvalifikacija)
F7 = {
id_kvalifikacija → dokument_kvalifikacija
}
Кандидат клуч: id_kvalifikacija.
Примарни атрибути: id_kvalifikacija.
R7 се наоѓа во BCNF, бидејќи има само една ф.з. и левата страна на таа ф.з. е суперклуч.


R8(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, ime_predmet, id_cas, vreme_pocetok_cas, tema_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F8 = {
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}
Кандидат клучеви: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje);
(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje)
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje, ime_predmet.
R8 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_cas → vreme_pocetok_cas.
id_cas ќе го ставиме во посебна релација R9, заедно со атрибутите кои тој ги определува. Останатото во R10.


R9(id_cas, vreme_pocetok_cas, tema_cas)
F9 = {
id_cas → vreme_pocetok_cas,
id_cas → tema_cas,
}
Кандидат клучеви: id_cas.
Примарни атрибути: id_cas.
R9 се наоѓа во BCNF, бидејќи левата страна на двете ф.з. е суперклуч.


R10(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, ime_predmet, id_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F10 = {
id_predmet → ime_predmet,
ime_predmet → id_predmet,
(id_predmet, id_ucenik) → datum_zainteresiran,
(ime_predmet, id_ucenik) → datum_zainteresiran,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}
Кандидат клучеви: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje);
(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, ime_predmet, id_cas, id_domasno, id_plakanja, id_slusanje)
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje, ime_predmet.
R10 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_predmet → ime_predmet.
id_predmet ќе го ставиме во посебна релација R11, заедно со атрибутите кои тој ги определува. Останатото во R12.


R11(id_predmet, ime_predmet)
F11 = {
id_predmet → ime_predmet,
ime_predmet → id_predmet,
}
Кандидат клучеви: id_predmet, ime_predmet.
Примарни атрибути: id_predmet, ime_predmet.
R11 се наоѓа во BCNF, бидејќи левата страна на двете ф.з. е суперклуч.


R12(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, iznos, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F12 = {
(id_predmet, id_ucenik) → datum_zainteresiran,
id_plakjanja → iznos,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}
Кандидат клучеви: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje);
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje.
R12 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_plakjanja → iznos.
id_plakjanja ќе го ставиме во посебна релација R13, заедно со атрибутите кои тој ги определува. Останатото во R14.


R13(id_plakjanja, iznos)
F13 = {
id_plakjanja → iznos
}
Кандидат клучеви: id_plakjanja.
Примарни атрибути: id_plakjanja.
R13 се наоѓа во BCNF, бидејќи има само една ф.з. и левата страна на таа ф.з. е суперклуч.


R14(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, opis_domasno, datum_zainteresiran, id_plakanja, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F14 = {
(id_predmet, id_ucenik) → datum_zainteresiran,
id_domasno → opis_domasno,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}
Кандидат клучеви: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje);
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, id_plakanja, id_slusanje.
R14 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е id_domasno → opis_domasno.
id_domasno ќе го ставиме во посебна релација R15, заедно со атрибутите кои тој ги определува. Останатото во R16.


R15(id_domasno, opis_domasno)
F15 = {
id_domasno → opis_domasno,
}
Кандидат клучеви: id_domasno.
Примарни атрибути: id_domasno.
R15 се наоѓа во BCNF, бидејќи има само една ф.з. и левата страна на таа ф.з. е суперклуч.


R16(id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_plakanja, id_slusanje, plateno, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F16 = {
(id_predmet, id_ucenik) → datum_zainteresiran,
(id_ucenik, id_domasno) → dali_zavrseno_domasno,
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
(id_nastavnik, id_predmet) → opis_predava_predmet,
(id_nastavnik, id_ucenik) → cena_po_cas,
(id_nastavnik, id_ucenik) → broj_casovi_po_dogovor
}
Кандидат клуч: (id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_plakanja, id_slusanje).
Примарни атрибути: id_admin, id_nastavnik, id_ucenik, id_kvalifikacija, id_predmet, id_cas, id_plakanja, id_slusanje.
R16 е во 1НФ поради парцијалните зависности. Една од повеќето ф.з. кои прават проблем е (id_cas, id_slusanje) → id_plakjanja.
Ја разделуваме релацијата на R17 и R18.


R17(id_cas, id_slusanje, id_plakjanja, id_ucenik, plateno)
F17 = {
(id_cas, id_slusanje) → id_plakjanja,
(id_cas, id_slusanje) → id_ucenik,
(id_cas, id_slusanje) → plateno,
}
Кандидат клуч: (id_cas, id_slusanje).
Примарни атрибути: id_cas, id_slusanje.
R17 e во BCNF поради тоа што левата страна на сите ф.з. е суперклуч.


R18(id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor, opis_predava_predmet)
F18 = {
(id_nastavnik, id_predmet) → opis_predava_predmet,
}
Кандидат клуч: (id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor);
Примарни атрибути: id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor
R18 е во 1НФ бидејќи парцијалната зависност (id_nastavnik, id_predmet) → opis_predava_predmet прави проблем.
Мора да ја декомпонираме. За таа цел ги добиваме релациите R19(id_nastavnik, id_predmet, opis_predava_predmet) и R20(id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor)


R19(id_nastavnik, id_predmet, opis_predava_predmet)
F19 = {
(id_nastavnik, id_predmet) → opis_predava_predmet,
}
Кандидат клуч: (id_nastavnik, id_predmet)
Примарни атрибути: id_nastavnik, id_predmet
R19 e во BCNF.


R20(id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor)
F20 = {} - празно множество - релацијата е во BCNF.


F1UF3UF5UF7UF9UF11UF13UF15UF17UF19UF20 е еквивалентно со Fc.
Декомпозицијата е без загуба на зависности односно сите првобитни зависности кои се наоѓаат во Fc, се содржат во унијата од сите горенаведени множества ф.з.
Тргнувајќи од почетокот на декомпозицијата, помеѓу секои две релации има барем еден заеднички атрибут кој е кандидат клуч на барем една од релациите. Според тоа нема загуба на информации и може да се направи join.


Краен резултат од релациите добиени по декомпозицијата (сите се во BCNF):
nastavnici
R1(id_nastavnik, prezime_nastavnik, opis_nastavnik, email_nastavnik, password_nastavnik, telefonski_broj_nastavnik)
admini
R3(id_admin, ime_admin, prezime_admin, email_admin, password_admin)
ucenici
R5(id_ucenik, ime_ucenik, prezime_ucenik, opis_ucenik, email_ucenik, password_ucenik, telefonski_broj_ucenik)
kvalifikacii
R7(id_kvalifikacija, dokument_kvalifikacija)
casovi
R9(id_cas, vreme_pocetok_cas, tema_cas)
predmeti
R11(id_predmet, ime_predmet)
plakjanja
R13(id_plakjanja, iznos)
domasni_zadaci
R15(id_domasno, opis_domasno)
plakanja_ucenik
R17(id_cas, id_slusanje, id_plakjanja, id_ucenik, plateno)
predava_predmet
R19(id_nastavnik, id_predmet, opis_predava_predmet)
evidencija
R20(id_admin, id_nastavnik, id_kvalifikacija, id_predmet, id_cas, id_domasno, datum_zainteresiran, id_slusanje, dali_zavrseno_domasno, cena_po_cas, broj_casovi_po_dogovor)

Last modified 2 years ago Last modified on 08/04/22 15:50:20
Note: See TracWiki for help on using the wiki.