Database Design Chapter Five DATABASE CONCEPTS, 6th Edition

Slides:



Advertisements
Similar presentations
Numbers Treasure Hunt Following each question, click on the answer. If correct, the next page will load with a graphic first – these can be used to check.
Advertisements

Chapter 4 Sampling Distributions and Data Descriptions.
AP STUDY SESSION 2.
1
Chapter 9 Structuring System Data Requirements
Copyright © 2003 Pearson Education, Inc. Slide 1 Computer Systems Organization & Architecture Chapters 8-12 John D. Carpinelli.
Copyright © 2011, Elsevier Inc. All rights reserved. Chapter 6 Author: Julia Richards and R. Scott Hawley.
Author: Julia Richards and R. Scott Hawley
1 Copyright © 2013 Elsevier Inc. All rights reserved. Chapter 3 CPUs.
David Burdett May 11, 2004 Package Binding for WS CDL.
1 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt BlendsDigraphsShort.
1 Click here to End Presentation Software: Installation and Updates Internet Download CD release NACIS Updates.
Managing Inventory throughout the Supply Chain
Break Time Remaining 10:00.
Turing Machines.
Table 12.1: Cash Flows to a Cash and Carry Trading Strategy.
PP Test Review Sections 6-1 to 6-6
© Paradigm Publishing, Inc Access 2010 Level 1 Unit 1Creating Tables and Queries Chapter 2Creating Relationships between Tables.
Copyright © 2011 Pearson Education, Inc. Publishing as Prentice Hall.
EIS Bridge Tool and Staging Tables September 1, 2009 Instructor: Way Poteat Slide: 1.
Bellwork Do the following problem on a ½ sheet of paper and turn in.
Exarte Bezoek aan de Mediacampus Bachelor in de grafische en digitale media April 2014.
Copyright © 2013, 2009, 2006 Pearson Education, Inc. 1 Section 5.5 Dividing Polynomials Copyright © 2013, 2009, 2006 Pearson Education, Inc. 1.
Copyright © 2012, Elsevier Inc. All rights Reserved. 1 Chapter 7 Modeling Structure with Blocks.
1 RA III - Regional Training Seminar on CLIMAT&CLIMAT TEMP Reporting Buenos Aires, Argentina, 25 – 27 October 2006 Status of observing programmes in RA.
Adding Up In Chunks.
1 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt 10 pt 15 pt 20 pt 25 pt 5 pt Synthetic.
Skills for Success with Microsoft® Office 2010
Functional Dependencies and Normalization for Relational Databases
Chapter 2 Entity-Relationship Data Modeling: Tools and Techniques
1 hi at no doifpi me be go we of at be do go hi if me no of pi we Inorder Traversal Inorder traversal. n Visit the left subtree. n Visit the node. n Visit.
Analyzing Genes and Genomes
Speak Up for Safety Dr. Susan Strauss Harassment & Bullying Consultant November 9, 2012.
McGraw-Hill/Irwin Copyright © 2007 by The McGraw-Hill Companies, Inc. All rights reserved. Chapter 12 View Design and Integration.
Essential Cell Biology
Clock will move after 1 minute
Intracellular Compartments and Transport
PSSA Preparation.
Essential Cell Biology
Immunobiology: The Immune System in Health & Disease Sixth Edition
Physics for Scientists & Engineers, 3rd Edition
Energy Generation in Mitochondria and Chlorplasts
Select a time to count down from the clock above
Data Modeling and the Entity-Relationship Model
Data Modeling and the Entity-Relationship Model
Database Lecture Notes Mapping ER Diagrams to Tables 2 Dr. Meg Murray
Data Modeling and the Entity-Relationship Model Chapter Four DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 3 rd Edition.
(wrapping up from last week)
Data Modeling and the Entity-Relationship Model
Database Design Chapter Five DATABASE CONCEPTS, 6th Edition
Entity-Relationship Model
Data Modeling and the Entity-Relationship Model
Data Modeling and the Entity-Relationship Model
The Relational Model Chapter Two DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 7 th Edition.
Data Modeling and the Entity-Relationship Model Chapter Four DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 5 th Edition.
Database Design Chapter Five DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 7 th Edition.
Database Design Chapter Five DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 5 th Edition.
Entity-Relationship Model
Database Design Chapter Five DAVID M. KROENKE’S DATABASE CONCEPTS, 2 nd Edition.
KROENKE and AUER - DATABASE CONCEPTS (3 rd Edition) © 2008 Pearson Prentice Hall 5-1 Chapter Objectives Learn how to transform E-R data models into relational.
© 2002 by Prentice Hall 1 Database Design David M. Kroenke Database Concepts 1e Chapter 5 5.
Database Design IST210 Class Lecture
+ Data Modeling (wrapping up from last week). + Homework Review Exercise 4.32 – Develop a data model of a genealogical diagram. Model only biological.
Data Modeling IST210 Class Lecture.
Database Design Chapter Five DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 3 rd Edition.
David M. Kroenke and David J. Auer Database Processing: F undamentals, Design, and Implementation Chapter Three: The Relational Model and Normalization.
Chapter 4: Logical Database Design and the Relational Model
Database Design Chapter Five DATABASE CONCEPTS, 4th Edition
Copyright © 2018, 2015, 20 Pearson Education, Inc. All Rights Reserved Database Concepts Eighth Edition Chapter # 2 The Relational Model.
Presentation transcript:

Database Design Chapter Five DATABASE CONCEPTS, 6th Edition DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 6th Edition Chapter Five Database Design

Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Printed in the United States of America. Copyright © 2013 Pearson Education, Inc.   Publishing as Prentice Hall KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Chapter Objectives Learn how to transform E-R data models into relational designs Practice applying the normalization process Understand the need for denormalization Learn how to represent weak entities with the relational model Know how to represent 1:1, 1:N, and N:M binary relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Chapter Objectives (Cont’d) Know how to represent 1:1, 1:N, and N:M recursive relationships Learn SQL statements for creating joins over binary and recursive relationships Understand the nature and background of normalization theory KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Transforming a Data Model into a Relational Design KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Entities with the Relational Model Create a relation for each entity. A relation has a descriptive name and a set of attributes that describe the entity. Specify a primary key. Specify column properties: Data type Null status Default values (if any) Data constraints (if any) The relation is then analyzed using the normalization rules. As normalization issues arise, the initial relation design may need to change. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing an Entity as a Table ITEM (ItemNumber, Description, Cost, ListPrice, QuantityOnHand) Figure 5-2: The ITEM Entity and Table KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

The Entity Table with Column Characteristics ITEM (ItemNumber, Description, Cost, ListPrice, QuantityOnHand) Figure 5-3: The Final ITEM Table KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Modification Problems Tables that are not normalized will experience issues known as modification problems. Insertion problems Difficulties inserting data into a relation Modification problems Difficulties modifying data into a relation Deletion problems Difficulties deleting data from a relation KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Solving Modification Problems Most modification problems are solved by breaking an existing table into two or more tables through a process known as normalization. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Definition Review Functional dependency The relationship (within the relation) that describes how the value of one attribute may be used to find the value of another attribute. Determinant The attribute that can be used to find the value of another attribute in the relation The right-hand side of a functional dependency KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Definition Review II Candidate key The value of a candidate key can be used to find the value of every other attribute in the table. A simple candidate key consists of only one attribute. A composite candidate key consists of more than one attribute. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Normal Forms There are many defined normal forms: First Normal Form (1NF) Second Normal Form (2NF) Third Normal Form (3NF) Boyce-Codd Normal Form (BCNF) Fourth Normal Form (4NF) Fifth Normal Form (5NF) Domain/Key Normal Form (DK/NF) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Normalization Review: Normalization For our purposes, a relation is considered normalized when: Every determinant is a candidate key. [Technically, this is Boyce-Codd Normal Form (BCNF)] KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

The CUSTOMER Table ZIP→(City, State) ContactName→Phone CUSTOMER (CustomerNumber, CustomerName, StreetAddress, City, State, ZIP, ContactName, Phone) ZIP→(City, State) ContactName→Phone Figure 5-4: The CUSTOMER Entity and Table KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

The CUSTOMER Entity: The Normalized Set of Tables CUSTOMER (CustomerNumber, CustomerName, StreetAddress, ZIP, ContactName) ZIP (ZIP, City, State) CONTACT (ContactName, Phone) Figure 5-5: The Normalized CUSTOMER and Associated Tables KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Denormalization Normalizing relations (or breaking them apart into many component relations) may significantly increase the complexity of the data structure. The question is one of balance. Trading complexity for modification problems There are situations where denormalized relations are preferred. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

The CUSTOMER Entity: The Denormalized Set of Tables CUSTOMER (CustomerNumber, CustomerName, StreetAddress, City, State, ZIP, ContactName) CONTACT (ContactName, Phone) Figure 5-6: The Denormalized CUSTOMER and Associated CONTACT Tables KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Weak Entities If not ID-dependent, use the same techniques as for strong entities. If ID-dependent, then must add primary key of the parent entity. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Weak Entities Example Figure 5-9: Relational Representation of a Weak Entity KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:1 Relationships The maximum cardinality determines how a relationship is represented. 1:1 relationship The key from one relation is placed in the other as a foreign key. It does not matter which table receives the foreign key. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:1 Relationship Example Figure 5-10: 1:1 Strong Entity Relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships SQL for 1:1 Relationships SELECT * FROM LOCKER, EMPLOYEE WHERE LOCKER.LockerNumber = EMPLOYEE.LockerNumber; WHERE LOCKER.EmployeeNumber = EMPLOYEE.EmployeeNumber; KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:N Relationships Like a 1:1 relationship, a 1:N relationship is saved by placing the key from one table into another as a foreign key. However, in a 1:N the foreign key always goes into the many-side of the relationship. The 1 side is called the parent. The N side is called the child. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:N Relationship Example Figure 5-12: 1:N Strong Entity Relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships SQL for 1:N Relationships SELECT * FROM ITEM, QUOTATION WHERE ITEM.ItemNumber = QUOTATION.ItemNumber; KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships N:M Relationships To create an N:M relationship, a new table is created. This table is called an intersection table. An intersection table has a composite key consisting of the keys from each of the tables that it connects. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships N:M Relationship – Data Model Figure 5-13: N:M Strong Entity Relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships N:M Relationship – Database Design Figure 5-15: Representing an N:M Strong Entity Relationship KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships SQL for N:M Relationships SELECT * FROM STUDENT, CLASS, STUDENT_CLASS WHERE STUDENT.SID = STUDENT_CLASS.SID AND STUDENT_CLASS.ClassNumber = CLASS.ClassNumber; KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships Association Relationships When an intersection table has columns beyond those in the primary key, the relationship is called an association relationship. Figure 5-18: The Association Relationship KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships Supertype/Subtype Relationships The identifier of the supertype becomes the primary key and the foreign key of each subtype. Figure 5-20: Representing Subtypes KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships Recursive Relationships A recursive relationship is a relationship that a relation has with itself. Recursive relationships adhere to the same rules as binary relationships. 1:1 and 1:M relationships are saved using foreign keys. M:N relationships are saved by creating an intersecting relation. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships Recursive Relationships—Examples Figure 5-21: Example Recursive Relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:1 Recursive Relationship Examples SELECT * FROM PERSON1 AS A, PERSON1 AS B WHERE A.Person = B.PersonSponsored; FROM PERSON2 AS C, PERSON2 AS D WHERE C.Person = D.PersonSponsoredBy; Figure 5-22: Example 1:1 Recursive Relationships KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships 1:N Recursive Relationship Example SELECT * FROM CUSTOMER AS A, CUSTOMER AS B WHERE A.CustomerNumber = B.ReferredBy; Figure 5-23: Example 1:N Recursive Relationship KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Representing Relationships N:M Recursive Relationship Example Figure 5-24: Example of an N:M Recursive Relationship KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

SQL for N:M Recursive Relationships SELECT * FROM DOCTOR AS A, DOCTOR AS B, TREATMENT-INTERSECTION WHERE A.Name = TREATMENT-INTERSECTION.Physician AND TREATMENT-INTERSECTION.Patient = B.Name; KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Heather Sweeney Designs: Developing a Database Design Heather Sweeney Designs will be used as on ongoing example throughout Chapters 4, 5, 6, 7, and 8. Heather Sweeney is an interior designer who specializes in home kitchen design. She offers a variety of free seminars at home shows, kitchen and appliance stores, and other public locations. She earns revenue by selling books and videos that instruct people on kitchen design. She also offers custom-design consulting services. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Heather Sweeney Designs: Final Data Model Figure 5-25: The Final Data Model for Heather Sweeney Designs KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Specifying Column Properties Column properties must be specified for each table. The column properties for the HSD tables are on the next set of slides. KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications SEMINAR (a) SEMINAR Figure 5-26: Heather Sweeney Designs Column Specifications KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications CUSTOMER (b) CUSTOMER Figure 5-26: Heather Sweeney Designs Column Specifications (Cont’d) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications CONTACT (c) CONTACT Figure 5-26: Heather Sweeney Designs Column Specifications (Cont’d) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications INVOICE (d) INVOICE Figure 5-26: Heather Sweeney Designs Column Specifications (Cont’d) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications LINE_ITEM (e) LINE_ITEM Figure 5-26: Heather Sweeney Designs Column Specifications (Cont’d) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

HSD Column Property Specifications PRODUCT (f) PRODUCT Figure 5-26: Heather Sweeney Designs Column Specifications (Cont’d) KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Heather Sweeney Designs: Database Design Figure 5-27: Database Design for Heather Sweeney Designs KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Heather Sweeney Designs: Database Design Schema SEMINAR (SeminarID, SeminarDate, SeminarTime, Location, SeminarTitle) CUSTOMER (EmailAddress, LastName, FirstName, Phone, StreetAddress, City, State, ZIP) SEMINAR_CUSTOMER (SeminarID, EmailAddress) CONTACT (EmailAddress, ContactDate, ContactNumber, ContactType, SeminarID) PRODUCT (ProductNumber, Description, UnitPrice, QuantityOnHand) INVOICE (InvoiceNumber, InvoiceDate, PaymentType, SubTotal, Tax, Total, EmailAddress) LINE_ITEM (InvoiceNumber, LineNumber, Quantity, UnitPrice, Total, ProductNumber) [Referential integrity constraints are in a separate slide] KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

Heather Sweeney Designs: Referential Integrity Constraints Figure 5-28: Referential Integrity Constraint Enforcement for Heather Sweeney Designs KROENKE and AUER - DATABASE CONCEPTS (6th Edition) Copyright © 2013 Pearson Education, Inc. Publishing as Prentice Hall

End of Presentation on Chapter Five DAVID M. KROENKE and DAVID J. AUER DATABASE CONCEPTS, 6th Edition End of Presentation on Chapter Five Database Design