Presentation is loading. Please wait.

Presentation is loading. Please wait.

CS34311 Translating ER Schema to Relational Model.

Similar presentations


Presentation on theme: "CS34311 Translating ER Schema to Relational Model."— Presentation transcript:

1 CS34311 Translating ER Schema to Relational Model

2 cs34312 Basic Mapping So Far Simple algorithms covers base case Idea: Each entity type = separate relation Each relationship type = separate relation

3 cs34313 Simple Algorithm: Example 3 PRIMARY KEY (Part) = PRIMARY KEY (Contains) = FOREIGN KEY Contains (superPart) REFERENCES Part (pNumber) FOREIGN KEY Contains (subPart) REFERENCES Part (pNumber) Part (pName, pNumber) Contains (superPart, subPart, quantity)

4 cs34314 Next Let’s consider constraints Let’s reduce number of relations

5 cs34315 Refinement for Simple Mapping Primary Key for R’ is defined as: If the maximum cardinality of any Ei is 1, primary key for R’ = primary key for Ei

6 cs34316 Simple Algorithm: Example 3 PRIMARY KEY (Part) = PRIMARY KEY (Contains) = FOREIGN KEY Contains (superPart) REFERENCES Part (pNumber) FOREIGN KEY Contains (subPart) REFERENCES Part (pNumber) Part (pName, pNumber) Contains (superPart, subPart, quantity)

7 cs34317 Decreasing the Number of Relations Technique 1 If the relationship type R contains an entity type, say E, whose maximum cardinality is 1, then R may be represented as attributes of E.

8 cs34318 Example 1 If the relationship type R contains an entity type, say E, whose maximum cardinality is 1, then R may be represented as attributes of E.

9 cs34319 Example 1 Student (sNumber, sName, advisor, years) Professor (pNumber, pName) PRIMARY KEY (Student) = PRIMARY KEY (Professor) = FOREIGN KEY Student (advisor) REFERENCES Professor (pNumber) Question: Will Student.advisor attribute ever be NULL ? Answer: No !

10 cs343110 Example 2 Person (pNumber, pName, dept, years) Dept (dNumber, dName) PRIMARY KEY (Person) = PRIMARY KEY (Dept) = FOREIGN KEY Person (dept) REFERENCES Dept (dNumber) What about NULL attributes ? Dept and years may be null for a person

11 cs343111 Remember the Simple Algorithm: Example 3 PRIMARY KEY (Part) = PRIMARY KEY (Contains) = FOREIGN KEY Contains (superPart) REFERENCES Part (pNumber) FOREIGN KEY Contains (subPart) REFERENCES Part (pNumber) Part (pName, pNumber) Contains (superPart, subPart, quantity)

12 cs343112 Example 3 Part (pNumber, pname, superPart, quantity) PRIMARY KEY (Part) = FOREIGN KEY Part (superPart) REFERENCES Part (pNumber) Note: superPart indicates the superpart of a part, and it may be null

13 cs343113 Decreasing the Number of Relations Summary of Technique 1 If the relationship type R contains an entity type, say E, whose maximum cardinality is 1, then R may be represented as attributes of E. If cardinality of E is (1, 1), then no “new nulls” added If cardinality of E is (0, 1) then may add “new nulls”

14 cs343114 Decreasing the number of Relations Technique 2 If relationship type R between E1 and E2 is one-to-one [1:1], and the cardinality of E1 or of E2 is (1, 1), then we can combine everything into 1 relation

15 cs343115 Decreasing the number of Relations Technique 2 - Method Details Let us assume the cardinality of E1 in R is (1, 1). Then we create one relation for entity E2 And, we move all attributes of E1 and for R to be attributes of E2.

16 cs343116 Example 1 Student-BIG (sNumber, sName, pNumber, pName, years) PRIMARY KEY (Student) = CANDIDATE KEY (Student) = Note: pNumber, pName, and years can be null for students with no advisor

17 cs343117 Example 2 Student (sNumber, sName, pNumber, pName, years) PRIMARY KEY (Student) = CANDIDATE KEY (Student) = Note: pNumber cannot be null for any student.

18 cs343118 Decreasing the Number of Relations Technique 2 If relationship type R between E1 and E2 is one-to-one [1:1], and the cardinality of E1 or of E2 is (1, 1), then we can combine everything into 1 relation Not always recommended! Thus use with care ! While very compact, semantically may not be clearest choice !

19 cs343119 ER Model: Complex Attributes Composite Attribute: address Student sNamesumer sAge statestreet address city

20 cs343120 Mapping details Composite attribute in ER Include an attribute for every component of the composite attribute.

21 cs343121 ER Model: Complex Attributes Multivalued Attribute: major

22 cs343122 Mapping details Multi-valued attribute in ER We need a separate relation for any multi-valued attribute. Identify appropriate attributes, keys and foreign key constraints.

23 cs343123 Other details Composite attribute in ER Include an attribute for every component of the composite attribute. Multi-valued attribute in ER We need a separate relation for any multi-valued attribute. Identify appropriate attributes, keys and foreign key constraints.

24 cs343124 Example: Composite and Multi-valued attributes in ER Student (sNumber, sName, sAge, street, city, state) PRIMARY KEY (Student) = StudentMajor (sNumber, major) PRIMARY KEY (StudentMajor) = FOREIGN KEY StudentMajor (sNumber) REFERENCES Student (sNumber)

25 cs343125 Summary Simple algorithms covers base case Refinements : Reduce number of relations Refinements: Consider constraints (not NULL) Consider other ER constructs like complex and multi-valued attributes


Download ppt "CS34311 Translating ER Schema to Relational Model."

Similar presentations


Ads by Google