Lecture 2: E/R Diagrams and the Relational Model Thursday, January 4, 2001.

Slides:



Advertisements
Similar presentations
Relational Database. Relational database: a set of relations Relation: made up of 2 parts: − Schema : specifies the name of relations, plus name and type.
Advertisements

Information Systems Chapter 4 Relational Databases Modelling.
Lecture 6: Design Constraints and Functional Dependencies January 21st, 2004.
1 Relational Model and Translating ER into Relational.
1 Lecture 04 Entity/Relationship Modelling. 2 Outline E/R model (Chapter 5) From E/R diagrams to relational schemas (Chapter 5) Constraints in SQL (Chapter.
Lecture #2 October 5 th, 2000 Conceptual Modeling Administration: –HW1 available –Details on projects –Exam date –XML comment.
Functional Dependencies Definition: If two tuples agree on the attributes A, A, … A 12n then they must also agree on the attributes B, B, … B 12m Formally:
1 Lecture 3: Database Modeling (continued) April 5, 2002.
1 Conceptual Design with ER Model Lecture #2. 2 Lecture Outline Logistics Steps in building a database application Conceptual design with ER model.
Lecture 9: Conceptual Database Design January 27 th, 2003.
Multiplicity in E/R Diagrams
Functional Dependencies and Relational Schema Design.
The Relational Data Model Database Model (ODL, E/R) Relational Schema Physical storage ODL definitions Diagrams (E/R) Tables: row names: attributes rows:
1 Lecture 4: Database Modeling (end) The Relational Data Model April 8, 2002.
CS411 Database Systems Kazuhiro Minami
Database Design April 3, Projects, More Details Goal: build a DB application. (almost) anything goes. Groups of 3-4. End of week 2: groups formed.
Entity / Relationship Diagrams Objects entities Classes entity sets Attributes are like in ODL. Relationships: like in ODL except - not associated with.
Chapter 4 The Relational Model.
CS411 Database Systems Kazuhiro Minami 02: The Entity-Relationship Model.
E/R Diagrams and Functional Dependencies. Modeling Subclasses The world is inherently hierarchical. Some entities are special cases of others We need.
Lecture 08: E/R Diagrams and Functional Dependencies.
Database Management COP4540, SCS, FIU Relational Model Chapter 7.
Database Systems Lecture # 7 8 th Feb, Conceptual and Logical Design Person buys Product name pricenamessn Conceptual Model: Relational Model: (plus.
Conceptual Database Design. Building an Application with a DBMS Requirements modeling (conceptual, pictures) –Decide what entities should be part of the.
1 Introduction to Database Systems CSE 444 Lecture 07 E/R Diagrams October 10, 2007.
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.
Lecture 2: E/R Diagrams and the Relational Model Wednesday, April 3 rd, 2002.
Home Work. Design Principles and Weak Entity Sets.
1 Web Database The Relational Data Model Irvanizam Zamanhuri, M.Sc Computer Science Study Program Syiah Kuala University Website :
DatabaseIM ISU1 Chapter 7 ER- and EER-to-Relational Mapping Fundamentals of Database Systems.
Lecture 3: Conceptual Database Design and Schema Design April 12 th, 2004.
The Entity-Relationship Model CIS 4301 Lecture Notes 1/12/2006.
1 Lecture 08: E/R Diagrams and Functional Dependencies Friday, January 21, 2005.
Modeling Constraints Extracting constraints is what modeling is all about. But how do we express them? Examples: Keys: social security number uniquely.
COMP 430 Intro. to Database Systems ER Design Considerations Slides use ideas from Chris Ré.
Chapter 3 The Relational Model. Objectives u Terminology of relational model. u How tables are used to represent data. u Connection between mathematical.
High-level Database Models Prof. Yin-Fu Huang CSIE, NYUST Chapter 4.
IT 5433 LM3 Relational Data Model. Learning Objectives: List the 5 properties of relations List the properties of a candidate key, primary key and foreign.
ER Diagrams and Relational Model CS 174a (Winter 2015)
Lecture 4: The E/R Model Lecture 4 Today’s Lecture 1.E/R Basics: Entities & Relations ACTIVITY: Crayon time! 2.E/R Design considerations ACTIVITY: Crayon.
The Relational Data Model Database Model (ODL, E/R) Relational Schema Physical storage ODL definitions Diagrams (E/R) Tables: row names: attributes rows:
Lecture 5: Conceptual Database Design
Modeling Constraints Extracting constraints is what modeling is all about. But how do we express them? Examples: Keys: social security number uniquely.
COP5725 Database Management ER DIAGRAM AND RELATIONAL DATA MODEL
COP4710 Database Systems E-R Model.
Database Design Oct. 3, 2001.
Database Design Why do we need it? Consider issues such as:
Lecture 4 Lecture 4: The E/R Model.
02: ER Model Ch 4.1 – 4.4 Optionally, begin with Ch 2.1.
Conceptual Database Design
Translation of ER-diagram into Relational Schema
Cse 344 May 14th – Entities.
From E/R Diagrams to Relational Schema
Lecture 4: Database Modeling (continued)
Cse 344 May 11th – Entities.
Lecture 2: Database Modeling (end) The Relational Data Model
Lecture 06 Data Modeling: E/R Diagrams
name category name price makes Company Product stockprice buys employs
Functional Dependencies
CMPT 354: Database System I
Lecture 9: The E/R Model II
Functional Dependencies
Lecture 10: The E/R Model III
Lecture 5: The Relational Data Model
Lecture 06: SQL Monday, October 11, 2004.
CS4433 Database Systems E-R Model.
Terminology Product Attribute names Name Price Category Manufacturer
Lecture 08: E/R Diagrams and Functional Dependencies
Presentation transcript:

Lecture 2: E/R Diagrams and the Relational Model Thursday, January 4, 2001

Outline E/R Diagrams: 2.4 (except 2.4.2, 2.4.5), 2.5 (except 2.5.4) The Relational Model: 3.1, 3.2, 3.3 E/R to Relational: 3.5

Entity / Relationship Diagrams in Summary Product address buys Entity sets: Properties: Relationships:

What is a Relation ? A mathematical definition: –if A, B are sets, then a relation R is a subset of A x B A={1,2,3}, B={a,b,c,d}, R = {(1,a), (1,c), (3,b)} - makes is a subset of Product x Company: a b c d A= B= makes Company Product

Multiplicity of E/R Relations one-one: many-one many-many abcdabcd abcdabcd abcdabcd Note: the book uses a non-standard notation

E/R Relationships and Relations in Mathematics makes Company Product prod1 prod2 prod3 Company-a Company-b Company-c Company-d ProductCompany Makes Makes = a subset of Product x Company

Attributes on Relationshiops makes Company Product prod1 prod2 prod3 Company-a Company-b Company-c Company-d ProductCompany Makes price $1 $200 $50 Makes = still a subset of Product x Company, not of Product x Company x Price (what does this imply ?)

Multi-way Relationships How do we model a purchase relationship between buyers, products and stores? Purchase Product Person Store Can still model as a mathematical set (how ?)

Arrows in Multi-way Relationships (not in the book) Purchase Product Person Store “A person buys a product at most once” Limited expressive power. Cannot say: “a person buys at most one product”

Q: what does the arrow mean ? A: if I know the store, person, invoice, I know the movie too Rental VideoStore Person Movie Invoice Arrows in Multiway Relationships

Q: what do these arrow mean ? A: store, person, invoice determines movie and store, invoice, movie determines person Rental VideoStore Person Movie Invoice Arrows in Multiway Relationships

Q: how do I say: “invoice determines store” ? A: no good way; best approximation: Why is this incomplete ? Rental VideoStore Person Movie Invoice Arrows in Multiway Relationships

Roles in Relationships Purchase What if we need an entity set twice in one relationship? Product Person Store salesperson buyer

Converting Multi-way Relationships to Binary Purchase Product Person Store date

Converting Multi-way Relationships to Binary Purchase Person Store Product StoreOf ProductOf BuyerOf Moral: Find a nice way to say things. date

Design Principles Purchase Product Person What’s wrong? President PersonCountry Moral: be faithful!

What’s Wrong? Purchase Product Store date personName personAddr Moral: pick the right kind of elements.

What’s Wrong? Purchase Product Person Store date Dates Moral: don’t complicate life more than it already is.

Class Hierarchies Some objects (entities) in a class may be special define a new class better: define a subclass Products Software products Educational products We define subclasses in E/R

Understanding Subclasses Think in terms of records: –Product –SoftwareProduct –EducationalProduct field1 field2 field1 field2 field1 field2 field3 field4 field5

Product namecategory price isa Educational ProductSoftware Product Age Groupplatforms Subclasses in E/R Diagrams

C++: classes are disjoint p1 p2 p3 sp1 sp2 ep1 ep2 ep3 Difference between C++ and E/R inheritance Product SoftwareProduct EducationalProduct

E/R: entity sets overlap Difference between ODL and E/R inheritance SoftwareProduct EducationalProduct p1 p2 p3 sp1 sp2 ep1 ep2 ep3 Product

No need for multiple inheritance in E/R we have three entity sets, but four different kinds of objects SoftwareProduct EducationalProduct p1 p2 p3 sp1 sp2 ep1 ep2 ep3 Product esp1 esp2

Modeling Union Types With Subclasses FurniturePiece Person Company Say: each piece of furniture is owned either by a person, or by a company

Modeling Union Types with Subclasses Say: each piece of furniture is owned either by a person, or by a company Solution 1. Acceptable, imperfect (What’s wrong ?) FurniturePiecePerson Company ownedByPerson

Modeling Union Types with Subclasses Solution 2: better, more laborious isa FurniturePiece Person Company ownedBy Owner isa

Constraints A constraint = an assertion about the database that must be true at all times part of the db schema types in programming languages do not have anything similar correspond to invariants in programming languages

Common Constraints in E/R Keys: social security number uniquely identifies a person. Single-value constraints: e.g. one-one, one-many, many-one Participation constrain: total many-one Domain constraints: peoples’ ages are between 0 and 150. General constraints: all others (at most 50 students enroll in a class)

Keys A set of attributes that uniquely identify an object or entity: Person: ssn name name + address name + address + age Perfect keys are often hard to find, so organizations usually invent something. An object may have multiple keys: employee number, ssn

Keys in E/R Diagrams address namessn Person Product namecategory price No formal way to specify multiple keys in E/R diagrams

Single Value Constraints in E/R makes Company Product A product is made by at most one company: Notice: some products are not made by any company

Participation Constraint makes Company Product makes Company Product Each product is made by a lest one company (notation from the book) Each product is made by exactly one company This: also called referential integrity constraint

Referential Integrity Constraint Another notation (in Ullman’s book): CompanyProduct makes CompanyProduct makes

Weak Entity Sets Entity sets are weak when their key attributes come from other classes to which they are related. This happens if: - part-of hierarchies - splitting n-ary relations to binary. UniversityTeam affiliation numbersportname

The Relational Data Model Database Model (E/R) Relational Schema Physical storage Diagrams (E/R) Tables: column names: attributes rows: tuples Complex file organization and index structures.

Terminology Name Price Category Manufacturer gizmo $19.99 gadgets GizmoWorks Power gizmo $29.99 gadgets GizmoWorks SingleTouch $ photography Canon MultiTouch $ household Hitachi tuples Attribute names Table name Products:

Domains each attribute has a type must be atomic type (why ? see later) called domain examples: –Integer –String –Real –…

Schemas Relational Schema: –Relation name plus attribute names –E.g. Product(Name, Price, Category, Manufacturer) –In practice we add the domain for each attribute Database Schema: –Set of relational schemas –E.g. Product(Name, Price, Category, Manufacturer) Vendor(Name, Address, Phone)

Instances An instance of a relational schema R(A1,…,Ak), is a relation with k attributes with values of corresponding domains An instance of a database schema R1(…), R2(…), …, Rn(…), consists of n relations, each an instance of the corresponding relational schema.

Example Name Price Category Manufacturer gizmo $19.99 gadgets GizmoWorks Power gizmo $29.99 gadgets GizmoWorks SingleTouch $ photography Canon MultiTouch $ household Hitachi Relational schema:Product(Name, Price, Category, Manufacturer) Instance:

Schemas and Instances Analogy with programming languages: –Schema = type –Instance = value Important distinction: –Database Schema = stable over long periods of time –Database Instance = changes constantly, as data is inserted/updated/deleted

Two Mathematical Definitions of Relations Relation as cartesian product –tuple = element of string x int x string x string –E.g. t = (gizmo, 19, gadgets, GizmoWorks) –Product is subset of string x int x string x string –Order in the tuple is important ! (gizmo, 19, gadgets, GizmoWorks) (gizmo, 19, GizmoWorks, gadgets) –No attributes

Two Mathematical Definitions of Relations Relation as a set of functions –Fix the set of attributes A={name, price, category, manufacturer} –A tuple is a function t:A Domains –Relation = set of tuples –E.g. –Order in a tuple is not important –Attribute names are important {name gizmo, price 19, category gadgets, manufacturer gizmoWorks}

Two Definitions of Relations We will switch back and forth between these two: –Relational schemas with attribute names –Positional tuples, without attribute names

From E/R Diagrams to Relational Schema Each entity set  relation Each relationship  relation Special cases: –one-one, many-one relationships –subclasses –weak entity sets

address namessn Person buys makes employs Company Product namecategory Stock price name price

Entity Sets to Relations Product namecategory price Product: Name Category Price gizmo gadgets $19.99

Relationships to Relations makes Company Product namecategory Stock price name Relations: Product, Makes, Company: Product-name Product-Category Company-name Starting-year gizmo gadgets gizmoWorks 1963 Start Year price

Many-one Relationships makes Company Product namecategory Stock price name No need for Makes. Just modify Product: name category price StartYear companyName gizmo gadgets gizmoWorks Start Year price

Handling Weak Entity Sets UniversityTeam affiliation numbersportname Relation Team: Sport Number Affiliated University mud wrestling 15 Montezuma State U. - need all the attributes that contribute to the key of Team - don’t need a separate relation for Affiliation. (why ?)

Modeling Subclass Structure Product Educational Product Software Product ageGroup topic Platforms required memory isa

The right way Product(name, price, category, manufacturer) EducationalProduct( name, ageGroup, topic) SoftwareProduct( name, platforms, requiredMemory) Notice: each subclass stores only the additional attributes

Option #2: The Null Value Approach Have one table: Product ( name, price, manufacturer, age-group, topic, platforms, required-memory, educational-method) Some values in the table will be NULL, meaning that the attribute not make sense for the specific product.