High-level Database Models Prof. Yin-Fu Huang CSIE, NYUST Chapter 4.

Slides:



Advertisements
Similar presentations
Chapter 10: Designing Databases
Advertisements

High-Level Database Models Spring 2011 Instructor: Hassan Khosravi.
Constraints in Entity-Relationship Models Zaki Malik September 18, 2008.
Dale Roberts 1 Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI
The Entity-Relationship Model
Information Systems Chapter 4 Relational Databases Modelling.
Chapter 4 Notes. Entity-Relationship Model E/R Diagrams Weak Entity Sets Converting E/R Diagrams to Relations.
Design Principles: Faithfulness
Weak Entity Sets. Occasionally, entities of an entity set need “help” to identify them uniquely. Example. Crews might have a number and some description,
Weak Entity Sets. Occasionally, entities of an entity set need “help” to identify them uniquely. Entity set E is weak if in order to identify entities.
Design Principles: Faithfulness
System Concepts and Architecture Rose-Hulman Institute of Technology Curt Clifton.
Movies length titleyearfilmType Voices isa Cartoons isa MurderMystery weapon toStar Our Movie Example.
A four-way Relationship
Entity-Relationship Data Model Alex Ostrovsky. Presentation Overview ► Short historical overview ► Elements of E-R Model ► Basic organization & relationships.
From E/R Diagrams to Relations. The Relational Data Model Database Model (E/R) Relational Schema Physical storage Diagrams (E/R) Tables: row names: attributes.
The Entity-Relationship Data Model
1 Lecture 3: Database Modeling (continued) April 5, 2002.
Slides adapted from A. Silberschatz et al. Database System Concepts, 5th Ed. Entity-Relationship Model Database Management Systems I Alex Coman, Winter.
1 The Entity-Relationship Data Model Chapter 2 (Database Design)
Murali Mani The Entity- Relationship Model. Murali Mani Database Design Stages Application Requirements Conceptual Design Logical Design Physical Design.
Lecture 9: Conceptual Database Design January 27 th, 2003.
CS411 Database Systems Kazuhiro Minami
The Entity-Relationship Model. 421B: Database Systems - ER Model 2 Overview of Database Design q Conceptual Design -- A first model of the real world.
Data Modeling Using the Entity-Relationship Model
Ch5: ER Diagrams - Part 2 Much of the material presented in these slides was developed by Dr. Ramon Lawrence at the University of Iowa.
Database Systems The Entity-Relationship Model
Entity-Relationship Data Model N. Harika Lecturer(csc)
Concepts and Terminology Introduction to Database.
Database Management COP4540, SCS, FIU Relational Model Chapter 7.
CPSC 603 Database Systems Lecturer: Laurie Webster II, M.S.S.E., M.S.E.E., M.S.BME, Ph.D., P.E. Lecture 3 Introduction to a First Course in Database Systems.
Databases : Entity-Relationship Model 2007, Fall Pusan National University Ki-Joune Li These slides are made from the materials that Prof. Jeffrey D. Ullman.
Conversion E/R to Relational CIS 4301 Lecture Notes Lecture 6 - 1/31/2006.
©Silberschatz, Korth and Sudarshan2.1Database System Concepts Chapter 2: Entity-Relationship Model Entity Sets Relationship Sets Design Issues Mapping.
The Relational Model 01/28/2014 – Material from Chapter 4 (Chap2 and Chap3 make an appearance)
Tallahassee, Florida, 2015 COP4710 Database Systems E-R Model Fall 2015.
© D. Wong Ch. 2 Entity-Relationship Data Model (continue)  Data models  Entity-Relationship diagrams  Design Principles  Modeling of constraints.
Entity-Relationship Model
CPSC 603 Database Systems Lecturer: Laurie Webster II, M.S.S.E., M.S.E.E., M.S.BME, Ph.D., P.E. Lecture 2 Introduction to a First Course in Database Systems.
© D. Wong Ch. 3 (continued)  Database design problems  Functional Dependency  Keys of relations  Decompositions based on Functional Dependency.
Databases Illuminated Chapter 3 The Entity Relationship Model.
Home Work. Design Principles and Weak Entity Sets.
Databases 1 Fifth lecture. Entity-Relationship Model Diagrams Class hierarchies Weak entity sets From E/R diagrams to Relations 2.
advanced data modeling
CS 157B Database Systems Dr. T Y Lin. Updates 1.Red color denotes updated data (ppt) 2.Class participation will be part of “extra” credits to to “quiz.
Dale Roberts 1 Department of Computer and Information Science, School of Science, IUPUI Dale Roberts, Lecturer Computer Science, IUPUI
CPSC 603 Database Systems Lecturer: Laurie Webster II, M.S.S.E., M.S.E.E., M.S.BME, Ph.D., P.E. Lecture 4 Introduction to a First Course in Database Systems.
The Entity-Relationship Model CIS 4301 Lecture Notes 1/12/2006.
Entity-Relationship Model E/R Diagrams Converting E/R Diagrams to Relations.
Data Modeling and the Entity-Relationship Model CS 475 Lecture Notes.
The Relational Model of Data Prof. Yin-Fu Huang CSIE, NYUST Chapter 2.
1 10 Systems Analysis and Design in a Changing World, 2 nd Edition, Satzinger, Jackson, & Burd Chapter 10 Designing Databases.
© D. Wong Ch. 3 (part 1)  Relational Model basics  From E/R diagram to Relations.
A short revision on entity- relationship modelling.
Modeling: Entity-Relationship Diagrams
A short review on entity- relationship modelling.
1 Database Modeling (Semantic data modeling) ER Data Model –A high-level conceptual data model –Proposed by P. Chen (1976) –Widely used in DB design process.
ER Diagrams and Relational Model CS 174a (Winter 2015)
Hele-Mai Haav: CSC210-Spring*01 CSC230-Spring*03 Database Design.
COP Introduction to Database Structures
Logical Database Design and the Rational Model
Chap 3. High-Level Database Models
Chapter 7: Entity-Relationship Model
Constraints in Entity-Relationship Models
CPSC-310 Database Systems
Transforming E/R to Relational Model.
Database Dr. Roueida Mohammed.
Chapter 3: Multivalued Dependencies
Session 5: Weak Entity Sets and ER Model to Relational ( )
Chapter 6b: Database Design Using the E-R Model
Presentation transcript:

High-level Database Models Prof. Yin-Fu Huang CSIE, NYUST Chapter 4

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model Design phrase 1) What information will be stored 2) How information elements will be related to one another 3) What constraints may be assumed (See Fig. 4.1) High-level models: 1) E/R (Entity/Relationship) diagram 2) UML (Unified Modeling Language) 3) ODL (Object Description Language) Starting with a high-level model and then converting the design to the relational model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang Three principal element types: 1) Entity sets 2) Attributes 3) Relationships Entity Sets Entity set ↔ class However, the E/R model is a static concept, involving the structure of data and not the operations on data Attributes we assume that attributes are of primitive types, such as strings, integers, or reals. 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang Relationships Relationships are connections among two or more entity sets Entity-Relationship Diagrams Entity set ↔ rectangle Attribute ↔ oval Relationship ↔ diamond (See Fig. 4.2) 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang Instances of an E/R Diagram A relationship R that connects n entity sets E 1, E 2, …, E n may be imagined to have an “instance” that consists of a finite set of tuples (e 1, e 2, …, e n ), where each e i is chosen from the entities that are in the current instance of entity set E i Multiplicity of Binary E/R Relationships Many-one One-one Many-many The arrows means “at most one” (See Fig. 4.3) 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model Multiway Relationships Example (See Fig. 4.4) Roles in Relationships It is possible that one entity set appears two or more times in a single relationship. Each line to the entity set represents a different role that the entity set plays in the relationships. Example (See Fig. 4.5 and Fig. 4.6)

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model Attributes on Relationships Example (See Fig. 4.7) We can instead invent a new entity set, whose entities have the attributes ascribed to the relationship. (See Fig. 4.8) Converting Multiway Relationships to Binary Any relationship connecting more than two entity sets can be converted to a collection of binary, many-one relationships. A connecting entity set (See Fig. 4.9)

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model Subclasses in the E/R Model “isa” relationships “an A is a B” expresses an “isa” relationship from entity set A to entity set B. (See Fig. 4.10) Example e.g., Roger Rabbit The three components are connected into one entity by the isa relationships.

Database Systems Yin-Fu Huang 4.1The Entity-Relationship Model

Database Systems Yin-Fu Huang Faithfulness First and foremost, the design should be faithful to the specifications of the application Avoiding Redundancy We should be careful to say everything once only. e.g., having an attribute studioName of entity set Movies Reasons: 1) Extra space is required to represent the data. 2) An update-anomaly potential 4.2Design Principles

Database Systems Yin-Fu Huang Simplicity Counts Avoiding introducing more elements into your design than is absolutely necessary. (See Fig. 4.11) Choosing the Right Relationships Adding to our design every possible relationship is not often a good idea. 1) Redundancy 2) Update anomaly 3) Delete anomaly Example (See Fig. 4.7 and Fig. 4.12) 4.2Design Principles

Database Systems Yin-Fu Huang 4.2Design Principles

Database Systems Yin-Fu Huang 4.2Design Principles

Database Systems Yin-Fu Huang 4.2Design Principles

Database Systems Yin-Fu Huang Picking the Right Kind of Element Using attributes or using entity sets? Example Make the name and address of the studio be attributes of movies and eliminate the Studio entity set. Problems: 1) Redundancy: the address of the studio 2) Update anomaly 3) Delete anomaly If we did not record addresses of studios, then there is no harm in making the studio name an attribute of movies. 4.2Design Principles

Database Systems Yin-Fu Huang The conditions under which we prefer to use an attribute instead of an entity set: 1) All relationships in which E is involved must have arrows entering E. 2) The only key for E is all its attributes. 3) No relationship involves E more than once. Replacing E: 1) If there is a many-one relationship R from some entity set F to E, then remove R and make the attributes of E be attributes of F. 4.2Design Principles

Database Systems Yin-Fu Huang 2) If there is a multiway relationship R with an arrow to E, make the attributes of E be attributes of R and delete the arc from R to E. Tradeoff between using a multiway relationship and using a connecting entity set Example More studios (See Fig. 4.13) 4.2Design Principles

Database Systems Yin-Fu Huang 4.2Design Principles

Database Systems Yin-Fu Huang Keys in the E/R Model Every entity set must have a key. There can be more than one possible key for an entity set. When an entity set is involved in an isa-hierarchy, we require that the root entity set have all the attributes needed for a key, and that the key for each entity is found from its component in the root entity set Representing Keys in the E/R Model Example (See Fig. 4.17) 4.3Constraints in the E/R Model

Database Systems Yin-Fu Huang 4.3Constraints in the E/R Model

Database Systems Yin-Fu Huang Referential Integrity A value appearing in one context must also appear in another. e.g., relationship Owns from Movies to Studios Example (See Fig. 4.18) Degree Constraints A bounding number to the edges that connect a relationship to an entity set Example (See Fig. 4.19) 4.3Constraints in the E/R Model

Database Systems Yin-Fu Huang 4.3Constraints in the E/R Model

Database Systems Yin-Fu Huang 4.3Constraints in the E/R Model

Database Systems Yin-Fu Huang It is possible for an entity set’s key to be composed of attributes, some or all of which belong to another entity set Causes of Weak Entity Sets Two principal reasons: 1) A hierarchy based on classifications unrelated to the “isa hierarchy” 2) The connecting entity sets Example key: (Studios)name+(Crews)number (See Fig. 4.20) 4.4Weak Entity Sets

Database Systems Yin-Fu Huang 4.4Weak Entity Sets

Database Systems Yin-Fu Huang key: (Genus)name+(Species)name (See Fig. 4.21) key: (Stars)name+(Studios)name+(Movies)(title+year) (See Fig. 4.22) Requirements for Weak Entity Sets If E is a weak entity set then its key consists of: 1) zero or more of its own attributes, and 2) key attributes from entity sets that are reached by certain many-one relationships from E to other entity sets, called supporting relationships for E. 4.4Weak Entity Sets

Database Systems Yin-Fu Huang 4.4Weak Entity Sets

Database Systems Yin-Fu Huang 4.4Weak Entity Sets

Database Systems Yin-Fu Huang In order for R to be a supporting relationship for E, the following conditions must be obeyed: 1) R must be a binary, many-one relationship from E to F. 2) R must have referential integrity from E to F. 3) The attributes that F supplies for the key of E must be key attributes of F. 4) If F is itself weak, then some or all of the key attributes of F supplied to E will be key attributes of one or more entity sets G to which F is connected by a supporting relationship. 4.4Weak Entity Sets

Database Systems Yin-Fu Huang 5) If there are several different supporting relationships from E to F, then each relationship is used to supply a copy of the key attributes of F to help form the key of E Weak Entity Set Notation If an entity set is weak, it will be shown as a rectangle with a double border. Its supporting many-one relationships will be shown as diamonds with a double border. If an entity set supplies any attributes for its own key, then those attributes will be underlined. 4.4Weak Entity Sets

Database Systems Yin-Fu Huang It is possible for there to be many-one relationships from a weak entity set that are not supporting relationships, and therefore do not get a double diamond. e.g., relationship: Studio-of (Each movie has a unique owning studio, determined by the many-one relationship from Movies to Studios.) 4.4Weak Entity Sets

Database Systems Yin-Fu Huang Converting an E/R design to a relational database schema: 1) Turn each entity set into a relation with the same set of attributes, and 2) Replace a relationship by a relation whose attributes are the keys for the connected entity sets. Several special situations: 1) Weak entity sets cannot be translated straightforwardly to relations. 2) “Isa” relationships and subclasses require careful treatment. 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 3) Sometimes, we do well to combine two relations, especially the relation for an entity set E and the relation that comes from a many-one relationship from E to some other entity set From Entity Sets to Relations Example (See Fig. 4.23) From E/R Relationships to Relations Relationships in the E/R model are also represented by relations. 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 1) For each entity set involved in relationship R, we take its key attribute or attributes as part of the schema of the relation for R. 2) If the relationship has attributes, then these are also attributes of relation R. Example (See Fig and Fig. 4.25) Key of Contracts: starName+title+year+studioOfStar +producingStudio 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang Combining Relations One common situation occurs when there is an entity set E with a many-one relationship R from E to F. The relations E and R can be combined into one relation with a schema consisting of: 1) All attributes of E 2) The key attributes of F 3) Any attributes belonging to relationship R Example (See Fig. 4.26) 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang But not for a many-many relationship Example (See Fig. 4.27) Handling Weak Entity Sets Three things for weak entity sets: 1) The relation for the weak entity set W itself must include not only the attributes of W but also the key attributes of the supporting entity sets. 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 2) The relation for any relationship in which the weak entity set W appears must use as a key for W all of its key attributes, including those of other entity sets that contribute to W's key. 3) A supporting relationship R need not be converted to a relation at all. Example (See Fig. 4.28) No relation for Unit-of 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang 4.5From E/R Diagrams to Relational Designs

Database Systems Yin-Fu Huang The principal conversion strategies are: 1) Follow the E/R viewpoint. For each entity set E in the hierarchy, create a relation that includes the key attributes from the root and any attributes belonging to E. 2) Treat entities as objects belonging to a single class. For each possible subtree that includes the root, create one relation, whose schema includes all the attributes of all the entity sets in the subtree. 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang 3) Use null values. Create one relation with all the attributes of all the entity sets in the hierarchy. Each entity is represented by one tuple, and that tuple has a null value for whatever attributes the entity does not have E/R-Style Conversion We do not create a relation for “isa”. Example (See Fig. 4.31) 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang Movies(title, year, length, genre) MurderMysteries(title, year, weapon) Cartoons(title, year) Voices(title, year, starName) The movies that are both cartoons and murder mysterieshave tuples in all first three relations. There may be silent cartoons in our database An Object-Oriented Approach Example 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang Movies(title, year, length, genre) MoviesC(title, year, length, genre) MoviesMM(title, year, length, genre, weapon) MoviesCMM(title, year, length, genre, weapon) Voices(title, year, starName) Using Null Values to Combine Relations Example Movies(title, year, length, genre, weapon) 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang Comparison of Approaches A list of the principal issues: 1) We would prefer to find all the attributes we needed to answer a query in one relation. Nulls approach √ ∗ A query like “what films of 2008 were longer than 150 minutes?” Straight-E/R approach √ Object-Oriented approach × 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang ∗ A query like “what weapons were used in cartoons of over 150 minutes in length?” Straight-E/R approach × Object-Oriented approach √ 2) We would like not to use too many relations. Nulls approach: only one relation Straight-E/R approach: only one relation per entity set in the hierarchy Object-Oriented approach: 2 n relations if n children 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang 3) We would like to minimize space and avoid repeating information. Object-Oriented approach: only one tuple per entity Nulls approach: only one tuple per entity, but these tuples are “long”. Straight-E/R approach: several tuples for each entity, but only the key attributes are repeated. 4.6Converting Subclass Structures to Relations

Database Systems Yin-Fu Huang The End.