220 likes | 396 Views
NORMALISATION. Introduction. Overview Objectives Intro. to Subject Why we normalise 1, 2 & 3 NF Normalisation Process Example Summary. Overview. The development of the application (creating an Access database) is usually one of the easiest steps in the process.
E N D
Introduction • Overview • Objectives • Intro. to Subject • Why we normalise • 1, 2 & 3 NF • Normalisation Process • Example • Summary
Overview The development of the application (creating an Access database) is usually one of the easiest steps in the process. Correct design of the database is one of the hardest steps but is of the utmost importance. In this lecture we concentrate upon this.
Objectives By the end of this lecture the student should: • Appreciate the need for normalisation • Understand what is meant by 1st, 2nd & 3rd Normal Form • Be able to perform simple normalisation
Intro. to Subject • DFD’s provide data flow info and process modelling • ERM provides entities & attributes (top down modelling) • Normalisation is designing a robust DB (bottom up modelling)
Why Normalise ? • Data Modelling captures the data a system needs to store • Normalisation has two main objectives: ID of entities Logical model
How it links to Access • All data of interest to system belongs in one database • Each entity is an Access table • Each attribute is an Access field • Using Normalisation you will identify the primary key
Normalisation • Normalisation is an algorithm for reducing complex data structures to simple structures • Also known as Codd’s or Boyce Codd’s law
Normalisation • Data that is not normalised can create insert/update/delete anomalies. • Minimise Data Redundancy • Achieve logical data grouping • Will not ensure that we have captured all the data
First Normal Form (1NF) • Definition: An entity is in First Normal Form if it has an identifying key and there are no repeating attributes or groups of attributes
First Normal Form (1NF) To remove repeating groups: • *Leave non-repeating attributes alone ( 1NF entity) • *Remove repeating attributes to separate 1NF entity whose key will be original key + key to repeating group
Second Normal Form (2NF) Definition: An entity is in 2NF if it is in first normal form and has no attributes which require only part of the key to identify them uniquely.
Second Normal Form (2NF) • To remove part-key dependencies • check that each non -key attribute depends on the whole key to determine it. • for each subset of a key, create a new separate entity
Third Normal Form (3NF) Definition: An entity is in 3NF if and only if it is in 2NF and no non-key attribute depends on any other non-key
Keys A Simple key is the unique identifier. A Compound key is made up of two or more simple keys. This creates the link between the two entities. A Foreign key is a non-key attribute in one entity which is a key attribute in another.
Example For example a school has four floors and on each floor there are rooms one to twenty. Floor and room repeat; to identify a single room we use: (Floor Number) (Room Number) The brackets mean that the lower level non-unique identifier room number must have the higher level unique identifier to make the whole key unique.
Example Course Registration Record Course Record Course Code: FR001 Course Description: Beginning French
Example UNF UNF Level Course Code 1 Course Descr. 1 E-No 2 Name 2 Hours 2 Room 2 Tel-no 2
Example 1NF Course Code Course Descr Course Code E-No Name Hours Room Tel-no
Example 2NF Course Code Course Descr Course Code E-No Hours E-No Name Room Tel-No
Example 3NF Course Code Course Descr Course Code E-No Hours E-No Name Room* Room Tel-No Thus we haveidentified FOUR entities: Course, Employee-on-Course, Employee & Room
Summary • Overview • Objectives • Intro. to Subject • Why we normalise • 1, 2 & 3 NF • Normalisation Process • Example