You are on page 1of 35

Introductory Database

Chapter 9

Instructor
Indra Chaudhary
meindra.ic@gmail.com
Introductory Database: Syllabus
2

Designing Good Designed Database


 Normalization
 Functional Dependencies: Multivalued, Partial,
transitive, join
 Update Anomalies
 Normal Forms: First, Second, Third, Fourth, Fifth
Normalization of Relation
3

 Normalization: The process of decomposing


unsatisfactory "bad" relations by breaking up their
attributes into smaller relations

 Normal form: Condition using keys and Functional


Dependencies of a relation to certify whether a
relation schema is in a particular normal form
Normalization of Relation
4

 Normalization is carried out in practice so that the


resulting designs are of high quality and meet the
desirable properties
 The practical utility of these normal forms becomes
questionable when the constraints on which they are
based are hard to understand or to detect
 The database designers need not normalize to the
highest possible normal form. (usually up to 3NF,
BCNF or 4NF)
 Denormalization: the process of storing the join of
higher normal form relations as a base relation—which
is in a lower normal form
Levels of Normalization
5

 Levels of normalization based on the amount of redundancy


in the database.
 Various levels of normalization are:
 First Normal Form (1NF)
 Second Normal Form (2NF)
 Third Normal Form (3NF)
 Boyce-Coded Normal Form (BCNF)
 Fourth Normal Form (4NF)
 Fifth Normal Form (5NF)
 Domain Key Normal Form (DKNF)

Most databases should be 3NF in order to avoid the database anomalies.


Levels of Normalization
6

1NF
2NF
3NF
4NF
5NF
DKNF

Each higher level is a subset of the lower level


7

Some Normalization Examples


Dependencies: Definitions
8

 Multivalued Attributes (or repeating groups): non-key


attributes or groups of non-key attributes the values of which
are not uniquely identified by (directly or indirectly) (not
functionally dependent on) the value of the Primary Key (or
its part).
STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Dependencies: Definitions
9

 Partial Dependency – when an non-key attribute is


determined by a part, but not the whole, of a
COMPOSITE primary key.
Partial
CUSTOMER Dependency

Cust_ID Name Order_ID


101 AT&T 1234
101 AT&T 156
125 Cisco 1250
Dependencies: Definitions
10

 Transitive Dependency – when a non-key attribute


determines another non-key attribute.
Transitive
Dependency

EMPLOYEE

Emp_ID F_Name L_Name Dept_ID Dept_Name


111 Mary Jones 1 Acct
122 Sarah Smith 2 Mktg
Normal Forms: Review
11

 Unnormalized – There are multivalued attributes


or repeating groups
 1 NF – No multivalued attributes or repeating
groups.
 2 NF – 1 NF plus no partial dependencies
 3 NF – 2 NF plus no transitive dependencies
Example 1: Determine NF
12

 ISBN  Title All attributes are directly


 ISBN  Publisher or indirectly determined by
the primary key; therefore,
 Publisher  Address the relation is at least in 1
NF

BOOK

ISBN Title Publisher Address


Example 1: Determine NF
13

 ISBN  Title The relation is at least in 1NF.


 ISBN  Publisher There is no COMPOSITE
primary key, therefore there
 Publisher  Address can’t be partial dependencies.
Therefore, the relation is at least
in 2NF
BOOK

ISBN Title Publisher Address


Example 1: Determine NF
14

 ISBN  Title
Publisher is a non-key attribute, and
 ISBN  Publisher it determines Address, another non-
 Publisher  Address key attribute. Therefore, there is a
transitive dependency, which means
that the relation is NOT in 3 NF.
BOOK

ISBN Title Publisher Address


Example 1: Determine NF
15

 ISBN  Title We know that the relation is at


 ISBN  Publisher least in 2NF, and it is not in 3 NF.
Therefore, we conclude that the
 Publisher  Address relation is in 2NF.

BOOK

ISBN Title Publisher Address


Example 1: Determine NF
16

 ISBN  Title In your solution you will write the


 ISBN  Publisher following justification:
1) No M/V attributes, therefore at least
 Publisher  Address 1NF
2) No partial dependencies, therefore at
least 2NF
3) There is a transitive dependency
(Publisher  Address), therefore, not
3NF
Conclusion: The relation is in 2NF

BOOK

ISBN Title Publisher Address


Example 2: Determine NF
17

 Product_ID  Description

All attributes are directly or indirectly


determined by the primary key;
therefore, the relation is at least in 1 NF
ORDER

Order_No Product_ID Description


Example 2: Determine NF
18

 Product_ID  Description

The relation is at least in 1NF.


There is a COMPOSITE Primary Key (PK) (Order_No,
Product_ID), therefore there can be partial dependencies.
Product_ID, which is a part of PK, determines
Description; hence, there is a partial dependency.
Therefore, the relation is not 2NF. No sense to check for
transitive dependencies!

ORDER

Order_No Product_ID Description


Example 2: Determine NF
19

 Product_ID  Description

We know that the relation is at least in


1NF, and it is not in 2 NF. Therefore, we
conclude that the relation is in 1 NF.

ORDER

Order_No Product_ID Description


Example 2: Determine NF
20

 Product_ID  Description

In your solution you will write the following


justification:
1) No M/V attributes, therefore at least 1NF
2) There is a partial dependency (Product_ID
 Description), therefore not in 2NF
Conclusion: The relation is in 1NF
ORDER

Order_No Product_ID Description


Example 3: Determine NF
21

 Part_ID  Description Comp_ID and No are not


 Part_ID  Price determined by the primary
key; therefore, the relation is
 Part_ID, Comp_ID  No NOT in 1 NF. No sense in
looking at partial or
transitive dependencies.

PART

Part_ID Descr Price Comp_ID No


Example 3: Determine NF
22

 Part_ID  Description In your solution you will write the


following justification:
 Part_ID  Price 1) There are M/V attributes;
 Part_ID, Comp_ID  No therefore, not 1NF
Conclusion: The relation is not
normalized.

PART

Part_ID Descr Price Comp_ID No


Bringing a Relation to 1NF
23

STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 1NF
24

 Option 1: Make a determinant of the repeating


group (or the multivalued attribute) a part of the
primary key.
Composite
Primary Key

STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 1NF
25

 Option 2: Remove the entire repeating group from the


relation. Create another relation which would contain all the
attributes of the repeating group, plus the primary key from
the first relation. In this new relation, the primary key from
the original relation and the determinant of the repeating
group will comprise a primary key.

STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 1NF
26

STUDENT

Stud_ID Name
101 Lennon
125 Jonson

STUDENT_COURSE

Stud_ID Course Units


101 MSI 250 3
101 MSI 415 3
125 MSI 331 3
Bringing a Relation to 2NF
27

Composite
Primary Key

STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 2NF
28

 Goal: Remove Partial Dependencies


Partial
Composite Dependencies
Primary Key

STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 2NF
29

 Remove attributes that are dependent from the part but not the
whole of the primary key from the original relation. For each
partial dependency, create a new relation, with the
corresponding part of the primary key from the original as the
primary key.
STUDENT

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 2NF
30

CUSTOMER STUDENT_COURSE
Stud_ID Name Course_ID Units
101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
Stud_ID Course_ID
125 Johnson MSI 331 3.00
101 MSI 250
101 MSI 415
125 MSI 331
STUDENT COURSE

Stud_ID Name Course_ID Units


101 Lennon MSI 250 3.00
101 Lennon MSI 415 3.00
125 Johnson MSI 331 3.00
Bringing a Relation to 3NF
31

 Goal: Get rid of transitive dependencies.

Transitive
Dependency
EMPLOYEE

Emp_ID F_Name L_Name Dept_ID Dept_Name


111 Mary Jones 1 Acct
122 Sarah Smith 2 Mktg
Bringing a Relation to 3NF
32

 Remove the attributes, which are dependent on a non-key


attribute, from the original relation. For each transitive
dependency, create a new relation with the non-key attribute
which is a determinant in the transitive dependency as a
primary key, and the dependent non-key attribute as a
dependent.
EMPLOYEE

Emp_ID F_Name L_Name Dept_ID Dept_Name


111 Mary Jones 1 Acct
122 Sarah Smith 2 Mktg
Bringing a Relation to 3NF
33
EMPLOYEE

Emp_ID F_Name L_Name Dept_ID Dept_Name


111 Mary Jones 1 Acct
122 Sarah Smith 2 Mktg

EMPLOYEE

Emp_ID F_Name L_Name Dept_ID


111 Mary Jones 1
122 Sarah Smith 2

DEPARTMENT

Dept_ID Dept_Name
1 Acct
2 Mktg
34
35

Thank You

You might also like