Well-Structured Relations
A well-structured relation contains minimal redundancy and allows users to insert, modify and delete the rows in a
table without errors or inconsistencies.
Redundancies in a table may result in errors or inconsistencies (called anomalies) when a user attempts to update
the data in the table. We are typically concerned about three types of anomalies:
1. Insertion anomaly: adding new rows forces user to create duplicate data
2. Deletion anomaly: deleting rows may cause a loss of data that would be needed for other future rows
3. Modification Anomaly: changing data in a row forces changes to other rows because of duplication
Normalization
Normalization is the process of successively reducing relations with anomalies to produce smaller, well-structured
relations. Following are some of the main goals of normalization:
Minimize data redundancy, thereby avoiding anomalies and conserving storage space
Simplify the enforcement of referential integrity constraints
Make it easier to maintain data (insert, update and delete)
Provide a better design that is an improved representation of the real world and a stronger basis for future growth
Normalization makes no assumptions about how data will be used in displays, queries, or reports. Normalization,
based on what we will call normal forms and functional dependencies, defines rules of the business, not data
usage. Further, remember that data are normalized by the end of logical database design. Thus, normalization,
places no constraints on how data can or should be physically stored or, therefore, on processing performance.
Normalization is a logical data modeling technique used to ensure that data are well-structured from an
organization-wide view.
Steps in Normalization
Normalization can be accomplished and understood in stages, each of which corresponds to a normal form. A
normal form is a state of a relation that requires that certain rules regarding relationships between attributes (or
functional dependencies) are satisfied. We describe these rules briefly in this section and illustrate them in detail in
the following sections:
1. First normal form Any multi-valued attributes (also called repeating groups) have been removed, so there
is a single value (possibly null) at the intersection of each row and column of the table
2. Second normal form Any partial functional dependencies have been removed (e.g. nonkey attributes are
identified by the whole primary key).
3. Third normal form Any transitive dependencies have been removed (e.g. nonkey attributes are identified
by only the primary key)
4. Boyce-Codd normal form Any remaining anomalies that result from functional dependencies have been
removed (because there was more than one possible primary key from the same nonkeys).
5. Fourth normal form Any multi-valued dependencies have been removed.
6. Fifth normal form Any remaining anomalies have been removed.
Functional Dependencies and Keys
A functional dependency is a constraint between two attributes or two sets of attributes.
EmpID, CourseTitle  DateCompleted
The comma between EmpID and CourseTitle stands for the logical AND operator, because DateCompleted is
functionally dependent on EmpID and CourseTitle in combination.
1|Relational Database Design
The functional dependency in this statement implies that the date a course is completed is determined by the
identity of the employee and the title of the course. Typical examples of functional dependencies are the
following:
1. SSN  Name, Address, birthplace A persons name, address and birthplace are functionally dependent
on a persons Social Security Number.
2. VIN  Make, Model, Color The make, model and color of a vehicle are functionally dependent on the
vehicle identification number.
3. ISBN  Title, FirstAuthorName, Publisher The title of a book, the name of the first author and the
publisher are functionally dependent on the books international standard book number (ISBN).
Determinants The attribute on the left side of the arrow in a functional dependency is called a determinant. SSN,
VIN, and ISBN are determinants (respectively) in the preceding three examples.
Candidate Keys A candidate key is an attribute or combination of attributes that uniquely identifies a row in a
relation. A candidate key must satisfy the following properties:
1. Unique identification For every row, the value of the key must uniquely identify that row. This property
implies that each nonkey is functionally dependent on that key.
2. Nonredundancy No attribute in the key can be deleted without destroying the property of unique
identification.
We can summarize the relationship between determinants and candidate keys as follows: A candidate key is
always a determinant, whereas a determinant may or may not be a candidate key.
2|Relational Database Design