Académique Documents
Professionnel Documents
Culture Documents
Relations that are in 3NF are also in BCNF. But, a 3NF relation is not in BCNF.
Thus the definition of 3NF permits a few additional functional dependencies involving
key attributes that are prohibited by BCNF. O, we can say that All BCNF is in 3NF, but
all 3NF is not in BCNF.
A 3NF relation may be in BCNF only if
(a) the candidate keys in the relation are composite keys (that is, they are not single
attributes),
(b) there is more than one candidate key in the relation, and
(c) the keys are not disjoint, that is, some attributes in the keys are common.
Example
Lets consider the database extract shown above. From this scenario we can extract the
following determinants:
DB(Patno,PatName,appNo,time,doctor) and Patno -> PatName
Patno,appNo -> Time,doctor
Time -> appNo
Now we have to decide what the primary key of DB is going to be. From the information
we have, we could chose:
DB(Patno,PatName,appNo,time,doctor)
DB(Patno,PatName,appNo,time,doctor)
DB(Patno,appNo,time,doctor)
R1(Patno,PatName)
DB(Patno,appNo,time,doctor)
R1(Patno,PatName)
BCNF: rewrite to
DB(Patno,time,doctor)
R1(Patno,PatName)
R2(time,appNo)
• BCNF is stronger than 3NF, relations that are in 3NF are not necessarily in BCNF
• BCNF is needed in certain situations to obtain full understanding of the data
model
• there are several routes to take to arrive at the same set of relations in BCNF.
• Unfortunately there are no rules as to which route will be the easiest one to take.
Information repetition
3NF- YES
BCNF- NO
We have seen BCNF and 3NF.
- It is always possible to obtain a 3NF design without sacri cing lossless-join or
dependency preservation.
- If we do not eliminate all transitive dependencies, we may need to use null values to
represent some of the meaningful relationships.
Example
Grade_report(StudNo,StudName,(Major,Adviser,
(CourseNo,Ctitle,InstrucName,InstructLocn,Grade)))
• Functional dependencies
• Unnormalised
Grade_report(StudNo,StudName,(Major,Advisor,
(CourseNo,Ctitle,InstrucName,InstructLocn,Grade)))
Student(StudNo,StudName)
StudMajor(StudNo,Major,Advisor)
StudCourse(StudNo,Major,CourseNo, Ctitle,InstrucName,InstructLocn,Grade)
Student(StudNo,StudName)
StudMajor(StudNo,Major,Advisor)
StudCourse(StudNo,Major,CourseNo,Grade)
Course(CourseNo,Ctitle,InstrucName,InstructLocn)
Student(StudNo,StudName)
StudMajor(StudNo,Major,Advisor)
StudCourse(StudNo,Major,CourseNo,Grade)
Course(CourseNo,Ctitle,InstrucName)
Instructor(InstructName,InstructLocn)
• BCNF
Student(StudNo,StudName)
StudCourse(StudNo,Major,CourseNo,Grade)
Course(CourseNo,Ctitle,InstrucName)
Instructor(InstructName,InstructLocn)
StudMajor(StudNo,Advisor)
Adviser(Adviser,Major)
ADVISO
STUDENT MAJOR
R
PHYSIC EINSTEI
123
S N
MOZAR
123 MUSIC
T
BIOLOG DARWI
456
Y N
PHYSIC
789 BOHR
S
PHYSIC EINSTEI
999
S N
• If the record for student 456 is deleted we lose not only information on student
456 but also the fact that DARWIN advises in BIOLOGY
• we cannot record the fact that WATSON can advise on COMPUTING until we
have a student majoring in COMPUTING to whom we can assign WATSON as
an advisor.
ADVISO
STUDENT
R
EINSTEI
123
N
MOZAR
123
T
DARWI
456
N
789 BOHR
EINSTEI
999
N
ADVISOR MAJOR
EINSTEIN PHYSIC
S
MOZART MUSIC
DARWIN BIOLOG
Y
BOHR PHYSIC
S