File notes/lectures_notes.md changed (mode: 100644) (index 0c32f72..5ca0025) |
... |
... |
CAR(VIN (PK), Make, Model, Year) |
851 |
851 |
DRIVER(State (PK), Licence\_number (PK), Name, Address)
|
DRIVER(State (PK), Licence\_number (PK), Name, Address)
|
852 |
852 |
INSURANCE(Policy\_Number (PK), Insured\_Car (FK to CAR.VIN), Insured\_Driver\_State (FK to DRIVER.State), Insured\_Driver\_Num (FK to DRIVER.Licence\_number), Rate)
|
INSURANCE(Policy\_Number (PK), Insured\_Car (FK to CAR.VIN), Insured\_Driver\_State (FK to DRIVER.State), Insured\_Driver\_Num (FK to DRIVER.Licence\_number), Rate)
|
853 |
853 |
PRICE(Stock\_number (PK), Car\_Vin (FK to CAR.VIN), Price, Margin)
|
PRICE(Stock\_number (PK), Car\_Vin (FK to CAR.VIN), Price, Margin)
|
854 |
|
](fig/rel_mod/CAR1)
|
|
|
854 |
|
](fig/rel_mod/car_01)
|
855 |
855 |
\
|
\
|
856 |
856 |
|
|
857 |
857 |
(Yes, we do need the state *and* the licence number to uniquely identify a driver's licence, since [many states use the same licence format](https://ntsi.com/drivers-license-format/).
|
(Yes, we do need the state *and* the licence number to uniquely identify a driver's licence, since [many states use the same licence format](https://ntsi.com/drivers-license-format/).
|
|
... |
... |
Exercise +.# |
1006 |
1006 |
AUTHOR(Ref, Name, Address)
|
AUTHOR(Ref, Name, Address)
|
1007 |
1007 |
BOOK(ISSN, AuthorRef, Title)
|
BOOK(ISSN, AuthorRef, Title)
|
1008 |
1008 |
GAINED-AWARD(Ref, Name, BookISSN, Year)
|
GAINED-AWARD(Ref, Name, BookISSN, Year)
|
1009 |
|
](fig/rel_mod/BOOK_Exo)
|
|
|
1009 |
|
](fig/rel_mod/book_exo)
|
1010 |
1010 |
\
|
\
|
1011 |
1011 |
|
|
1012 |
1012 |
For each relation, answer the following:
|
For each relation, answer the following:
|
|
... |
... |
Exercise +.# |
1022 |
1022 |
TRAIN(Ref (PK), Model, Year)
|
TRAIN(Ref (PK), Model, Year)
|
1023 |
1023 |
CONDUCTOR(CompanyID (PK), Name, ExperienceLevel)
|
CONDUCTOR(CompanyID (PK), Name, ExperienceLevel)
|
1024 |
1024 |
ASSIGNED-TO(TrainRef (PK, FK to TRAIN.Ref), ConductorID (PK, FK to CONDUCTOR.CompanyID), Date (PK))
|
ASSIGNED-TO(TrainRef (PK, FK to TRAIN.Ref), ConductorID (PK, FK to CONDUCTOR.CompanyID), Date (PK))
|
1025 |
|
](fig/rel_mod/TRAIN_Exo)
|
|
|
1025 |
|
](fig/rel_mod/train_exo)
|
1026 |
1026 |
\
|
\
|
1027 |
1027 |
|
|
1028 |
1028 |
#. What are the foreign keys in the ASSIGNED-TO relation? What are they refering?
|
#. What are the foreign keys in the ASSIGNED-TO relation? What are they refering?
|
|
... |
... |
Exercise +.# |
1078 |
1078 |
data:image/s3,"s3://crabby-images/d3c4f/d3c4f1a446df67dbef8283a7d6340fce552334a9" alt="
|
![
|
1079 |
1079 |
BUILDING(Name (PK), Address)
|
BUILDING(Name (PK), Address)
|
1080 |
1080 |
ROOM(Code (PK), Building (FK to BUILDING.Name))
|
ROOM(Code (PK), Building (FK to BUILDING.Name))
|
1081 |
|
"
|
|
|
1081 |
|
](fig/rel_mod/building_room)
|
1082 |
1082 |
\
|
\
|
1083 |
1083 |
|
|
1084 |
1084 |
#. Give two possible tuples for the BUILDING relation, and two possible tuples for the ROOM relation such that the state is consistent.
|
#. Give two possible tuples for the BUILDING relation, and two possible tuples for the ROOM relation such that the state is consistent.
|
|
... |
... |
Solution +.# |
1170 |
1170 |
AUTHOR(Ref (PK), Name, Address)
|
AUTHOR(Ref (PK), Name, Address)
|
1171 |
1171 |
BOOK(ISSN (PK), AuthorRef (FK to AUTHOR.REF), Title)
|
BOOK(ISSN (PK), AuthorRef (FK to AUTHOR.REF), Title)
|
1172 |
1172 |
GAINED-AWARD(Ref (PK), Name, BookISSN (FK to BOOK.ISSN), Year)
|
GAINED-AWARD(Ref (PK), Name, BookISSN (FK to BOOK.ISSN), Year)
|
1173 |
|
](fig/rel_mod/BOOK_Sol)
|
|
|
1173 |
|
](fig/rel_mod/book_sol)
|
1174 |
1174 |
\
|
\
|
1175 |
1175 |
|
|
1176 |
1176 |
For the last question, the answer is yes: based on the ISSN of the book, we can retrieve the author of the book. Hence, knowing which book was awarded which year, by looking in the GAINED-AWARD table, gives us the answer to that question.
|
For the last question, the answer is yes: based on the ISSN of the book, we can retrieve the author of the book. Hence, knowing which book was awarded which year, by looking in the GAINED-AWARD table, gives us the answer to that question.
|
|
... |
... |
Solution +.# |
1212 |
1212 |
data:image/s3,"s3://crabby-images/3db1d/3db1d724162efccd55a63fc2c0180eeef48a4ebb" alt="
|
![
|
1213 |
1213 |
MOVIE(Title (PK), Year)
|
MOVIE(Title (PK), Year)
|
1214 |
1214 |
CHARACTER(Name(PK), First_Appearance (FK referencing MOVIE.Title))
|
CHARACTER(Name(PK), First_Appearance (FK referencing MOVIE.Title))
|
1215 |
|
"
|
|
|
1215 |
|
](fig/rel_mod/character)
|
1216 |
1216 |
\
|
\
|
1217 |
1217 |
|
|
1218 |
1218 |
#. Inserting <"Ash", "Evil Dead"> into the **CHARACTER** relation would cause an error if the database was empty, since no movie with the primary key "Evil Dead" has been introduced yet: this would be a referential integrity constraint violation.
|
#. Inserting <"Ash", "Evil Dead"> into the **CHARACTER** relation would cause an error if the database was empty, since no movie with the primary key "Evil Dead" has been introduced yet: this would be a referential integrity constraint violation.
|
|
... |
... |
Solution to [%D %n (%T)](#problem:cinema) |
1301 |
1301 |
AUDITORIUM(ID (PK), Capacity, Theater (FK to THEATER.ID))
|
AUDITORIUM(ID (PK), Capacity, Theater (FK to THEATER.ID))
|
1302 |
1302 |
SHOWTIME(ID (PK), MovieId (FK to MOVIE.ID), AuditoriumId (FK to AUDITORIUM.ID), StartTime)
|
SHOWTIME(ID (PK), MovieId (FK to MOVIE.ID), AuditoriumId (FK to AUDITORIUM.ID), StartTime)
|
1303 |
1303 |
TICKETS(ID (PK), ShowTimeId (FK to SHOWTIME.ID), Price)
|
TICKETS(ID (PK), ShowTimeId (FK to SHOWTIME.ID), Price)
|
1304 |
|
](fig/rel_mod/CINEMA)
|
|
|
1304 |
|
](fig/rel_mod/cinema)
|
1305 |
1305 |
\
|
\
|
1306 |
1306 |
|
|
1307 |
1307 |
---
|
---
|
|
... |
... |
Solution to [%D %n (%T)](#problem:rel_model_bills) |
1316 |
1316 |
MEMBER(Name, Political Group, BTerm, ETerm, ID (PK))
|
MEMBER(Name, Political Group, BTerm, ETerm, ID (PK))
|
1317 |
1317 |
REPRESENTATIVE(Role (PK), Member (FK to MEMBER.ID))
|
REPRESENTATIVE(Role (PK), Member (FK to MEMBER.ID))
|
1318 |
1318 |
VOTE(Bill (PK, FK to BILL.ID), Member (PK, FK to MEMBER.ID))
|
VOTE(Bill (PK, FK to BILL.ID), Member (PK, FK to MEMBER.ID))
|
1319 |
|
](fig/rel_mod/BILL)
|
|
|
1319 |
|
](fig/rel_mod/bill)
|
1320 |
1320 |
\
|
\
|
1321 |
1321 |
|
|
1322 |
1322 |
For simplicity, we added an `ID` to our `MEMBER` and `BILL` relations. Note that having a "role" in the `MEMBER` relation to store the information about speaker, etc., would be extremely inefficient, since we would add an attribute to the ~435 members that would be `NULL`{.sqlmysql} in ~430 of them.
|
For simplicity, we added an `ID` to our `MEMBER` and `BILL` relations. Note that having a "role" in the `MEMBER` relation to store the information about speaker, etc., would be extremely inefficient, since we would add an attribute to the ~435 members that would be `NULL`{.sqlmysql} in ~430 of them.
|
|
... |
... |
CAMPUS (Address (PK), University (FK to UNIVERSITY.Name)) |
1337 |
1337 |
DEPARTMENT (Code (PK), Contact, CreationDate, University (FK to UNIVERSITY.Name))
|
DEPARTMENT (Code (PK), Contact, CreationDate, University (FK to UNIVERSITY.Name))
|
1338 |
1338 |
COURSE (Name (PK), CreditHours)
|
COURSE (Name (PK), CreditHours)
|
1339 |
1339 |
OFFERING (Department (PK, FK to DEPARTMENT.Name), Course (PK, FK to COURSE.Name), Code)
|
OFFERING (Department (PK, FK to DEPARTMENT.Name), Course (PK, FK to COURSE.Name), Code)
|
1340 |
|
](fig/rel_mod/UNIVERSITIES)
|
|
|
1340 |
|
](fig/rel_mod/universities)
|
1341 |
1341 |
\
|
\
|
1342 |
1342 |
|
|
1343 |
1343 |
|
|
|
... |
... |
MariaDB [HW_CONSTRAINTS_PART3]> SELECT * FROM Table_set_null; |
1923 |
1923 |
data:image/s3,"s3://crabby-images/9c32e/9c32e3f311108914ed761ae422b54e3cbc8872d0" alt="
|
![
|
1924 |
1924 |
PROF(Login (PK), Name, Department (FK to DEPARTMENT.Code))
|
PROF(Login (PK), Name, Department (FK to DEPARTMENT.Code))
|
1925 |
1925 |
DEPARTMENT(Code (PK), Name, Head (FK to PROF.Login))
|
DEPARTMENT(Code (PK), Name, Head (FK to PROF.Login))
|
1926 |
|
"
|
|
|
1926 |
|
](fig/rel_mod/prof_department)
|
1927 |
1927 |
\
|
\
|
1928 |
1928 |
|
|
1929 |
1929 |
~~~{.sqlmysql}
|
~~~{.sqlmysql}
|
|
... |
... |
Solution to [%D %n (%T)](#problem:address) |
4124 |
4124 |
data:image/s3,"s3://crabby-images/405e8/405e837f8381fd01f23cb45581ce80caa43ce96c" alt="
|
![
|
4125 |
4125 |
NAME(FName, LName, ID(PK))
|
NAME(FName, LName, ID(PK))
|
4126 |
4126 |
ADDRESS(StreetName (PK), Number (PK), Habitants (FK referencing NAME.ID))
|
ADDRESS(StreetName (PK), Number (PK), Habitants (FK referencing NAME.ID))
|
4127 |
|
"
|
|
|
4127 |
|
](fig/rel_mod/address)
|
4128 |
4128 |
\
|
\
|
4129 |
4129 |
|
|
4130 |
4130 |
@problem:address -- Solution to Q. -.#
|
@problem:address -- Solution to Q. -.#
|
|
... |
... |
Solution to [%D %n (%T)](#problem:profrevisited) |
4326 |
4326 |
LECTURE (Code (PK), Year (PK), Name, Instructor (FK to PROF.Login)
|
LECTURE (Code (PK), Year (PK), Name, Instructor (FK to PROF.Login)
|
4327 |
4327 |
STUDENT(Login (PK), Name, Registered, Major (FK to DEPARTMENT.Code))
|
STUDENT(Login (PK), Name, Registered, Major (FK to DEPARTMENT.Code))
|
4328 |
4328 |
GRADE (Login (PK, FK to STUDENT.Login), Grade (PK), LectureCode (FK to LECTURE.Code), LectureYear (FK to LECTURE.Year))
|
GRADE (Login (PK, FK to STUDENT.Login), Grade (PK), LectureCode (FK to LECTURE.Code), LectureYear (FK to LECTURE.Year))
|
4329 |
|
](fig/rel_mod/PROF_DEPARTMENT_EXTENDED)
|
|
|
4329 |
|
](fig/rel_mod/prof_department_extended)
|
4330 |
4330 |
\
|
\
|
4331 |
4331 |
|
|
4332 |
4332 |
For the other questions, refer to this code.
|
For the other questions, refer to this code.
|
|
... |
... |
Solution to [%D %n (%T)](#problem:coffee) |
4356 |
4356 |
CUSTOMER (CardNo (PK), Name, Email, FavCoffee (FK to COFFEE.Ref))
|
CUSTOMER (CardNo (PK), Name, Email, FavCoffee (FK to COFFEE.Ref))
|
4357 |
4357 |
SUPPLY (Provider (PK, FK to PROVIDEV.ID), Coffee (PK, FK to COFEE.Ref))
|
SUPPLY (Provider (PK, FK to PROVIDEV.ID), Coffee (PK, FK to COFEE.Ref))
|
4358 |
4358 |
PROVIDER (Name (PK), Email)
|
PROVIDER (Name (PK), Email)
|
4359 |
|
](fig/rel_mod/COFFEE)
|
|
|
4359 |
|
](fig/rel_mod/coffee)
|
4360 |
4360 |
\
|
\
|
4361 |
4361 |
|
|
4362 |
4362 |
|
|
|
... |
... |
Solution to [%D %n (%T)](#problem:roleplaying) |
4434 |
4434 |
QUEST(Name (PK), XP)
|
QUEST(Name (PK), XP)
|
4435 |
4435 |
COMPLETED-BY(Character (PK, FK to CHARACTER.Name), Quest (PK, FK to QUEST.Name))
|
COMPLETED-BY(Character (PK, FK to CHARACTER.Name), Quest (PK, FK to QUEST.Name))
|
4436 |
4436 |
SPECIAL-ITEM(Name (P), Quest (FK to QUEST.Name))
|
SPECIAL-ITEM(Name (P), Quest (FK to QUEST.Name))
|
4437 |
|
](fig/rel_mod/RPG)
|
|
|
4437 |
|
](fig/rel_mod/rpg)
|
4438 |
4438 |
\
|
\
|
4439 |
4439 |
|
|
4440 |
4440 |
---
|
---
|
|
... |
... |
Solution to [%D %n (%T)](#problem:sqlWorks) |
4575 |
4575 |
AUTHOR(Name (PK), Email)
|
AUTHOR(Name (PK), Email)
|
4576 |
4576 |
BOOK(ISBN (PK), Work (FK to WORK.Title), Published, Price)
|
BOOK(ISBN (PK), Work (FK to WORK.Title), Published, Price)
|
4577 |
4577 |
EBOOK(ISBN (PK), Work (FK to WORK.Title), Published, Price)
|
EBOOK(ISBN (PK), Work (FK to WORK.Title), Published, Price)
|
4578 |
|
](fig/rel_mod/WORK)
|
|
|
4578 |
|
](fig/rel_mod/work)
|
4579 |
4579 |
\
|
\
|
4580 |
4580 |
|
|
4581 |
4581 |
The solution to the next questions can be read from the following code:
|
The solution to the next questions can be read from the following code:
|
|
... |
... |
multivalued | the box have double lines | |
4704 |
4704 |
derived | the box have dotted lines |
|
derived | the box have dotted lines |
|
4705 |
4705 |
a key | the name of the attribute is underlined |
|
a key | the name of the attribute is underlined |
|
4706 |
4706 |
|
|
4707 |
|
data:image/s3,"s3://crabby-images/c67e4/c67e40c561f5562f8ee32536cc84e67af0660f81" alt=""
|
|
|
4707 |
|
data:image/s3,"s3://crabby-images/31160/311602de96746dbd63f9740f5f679702c081d46d" alt=""
|
4708 |
4708 |
\
|
\
|
4709 |
4709 |
|
|
4710 |
|
data:image/s3,"s3://crabby-images/242cb/242cb98a1e64077d314db36d2a212090b136207b" alt=""
|
|
|
4710 |
|
data:image/s3,"s3://crabby-images/eb3f9/eb3f9cc78fca28add30b1a31198a407c39ce6b34" alt=""
|
4711 |
4711 |
\
|
\
|
4712 |
4712 |
|
|
4713 |
4713 |
In the following, we'll focus on the relationship between the entities more than on the attributes of particular entities, so we'll sometimes simply draw
|
In the following, we'll focus on the relationship between the entities more than on the attributes of particular entities, so we'll sometimes simply draw
|
4714 |
4714 |
|
|
4715 |
|
data:image/s3,"s3://crabby-images/024c5/024c54272d5441131e7d9d2ed2ffc10648cfc365" alt=""
|
|
|
4715 |
|
data:image/s3,"s3://crabby-images/d9e48/d9e48c5a299b9c2073c6ac9ce70c88c190495d5c" alt=""
|
4716 |
4716 |
\
|
\
|
4717 |
4717 |
|
|
4718 |
4718 |
leaving the attributes un-specified (but that does not mean that they all have to be atomic) or even just
|
leaving the attributes un-specified (but that does not mean that they all have to be atomic) or even just
|
4719 |
4719 |
|
|
4720 |
4720 |
|
|
4721 |
|
data:image/s3,"s3://crabby-images/d23a9/d23a9bf753e844ad62214bfe7b3c17fe49989e3a" alt=""
|
|
|
4721 |
|
data:image/s3,"s3://crabby-images/7beca/7beca6c76d7b55b3f94a93ff01dc823c5f98e25c" alt=""
|
4722 |
4722 |
\
|
\
|
4723 |
4723 |
|
|
4724 |
4724 |
but that does not mean that the entity type have no attribute!
|
but that does not mean that the entity type have no attribute!
|
|
... |
... |
but that does not mean that the entity type have no attribute! |
4736 |
4736 |
|
|
4737 |
4737 |
$E_1$, … $E_n$ *participate* in R, $e_1$, …, $e_n$ *participate* in $r_1$, $n$ is the degree.
|
$E_1$, … $E_n$ *participate* in R, $e_1$, …, $e_n$ *participate* in $r_1$, $n$ is the degree.
|
4738 |
4738 |
|
|
4739 |
|
data:image/s3,"s3://crabby-images/459b8/459b820bdd6da56a23c01b684b0f1a278031afdd" alt=""
|
|
|
4739 |
|
data:image/s3,"s3://crabby-images/d828d/d828dc1c3f94b4953b24f4f6cee78510d2981631" alt=""
|
4740 |
4740 |
\
|
\
|
4741 |
4741 |
|
|
4742 |
4742 |
Note that we can have Entity Set 1 = Entity Set 2, in which case we say the relation is recursive.
|
Note that we can have Entity Set 1 = Entity Set 2, in which case we say the relation is recursive.
|
|
... |
... |
Naming convention: |
4749 |
4749 |
- Drawing usually reads right to left, and up to down.
|
- Drawing usually reads right to left, and up to down.
|
4750 |
4750 |
|
|
4751 |
4751 |
|
|
4752 |
|
data:image/s3,"s3://crabby-images/8147b/8147b011428564af6819cf23105fa8e1c9c475c0" alt=""
|
|
|
4752 |
|
data:image/s3,"s3://crabby-images/6149c/6149c7308a8558acf2f2533a6e72f4e213d477fc" alt=""
|
4753 |
4753 |
\
|
\
|
4754 |
4754 |
|
|
4755 |
4755 |
|
|
|
... |
... |
Convenient, and sometimes mandatory, to give role names. |
4759 |
4759 |
|
|
4760 |
4760 |
If we want to stress that we are considering only one aspect of an entity (that is, a person is not only an employee, a company is not only an employer, but this aspect is crucial for the "EMPLOYS" relation):
|
If we want to stress that we are considering only one aspect of an entity (that is, a person is not only an employee, a company is not only an employer, but this aspect is crucial for the "EMPLOYS" relation):
|
4761 |
4761 |
|
|
4762 |
|
data:image/s3,"s3://crabby-images/bc3f5/bc3f506d923f5ccaf87bb8b63f3b6c8c58edd9b5" alt=""
|
|
|
4762 |
|
data:image/s3,"s3://crabby-images/fb3fe/fb3fe1b1c689db87384d3784b3bdb2e34b505181" alt=""
|
4763 |
4763 |
|
|
4764 |
4764 |
We can also use it to make the "right-side" and the "left-side" of a recursive relationship explicit:
|
We can also use it to make the "right-side" and the "left-side" of a recursive relationship explicit:
|
4765 |
4765 |
|
|
4766 |
|
data:image/s3,"s3://crabby-images/c2a93/c2a93c4af9509a3fa3aaab7e11864ac8ddcb35d9" alt=""
|
|
4767 |
|
data:image/s3,"s3://crabby-images/4b82e/4b82e83960d20178b983cf95a8ab0161309d8a1e" alt=""
|
|
|
4766 |
|
data:image/s3,"s3://crabby-images/8d254/8d254742b90b81988e262bb9e9b5c2840244af05" alt=""
|
|
4767 |
|
data:image/s3,"s3://crabby-images/ecb64/ecb64a3c1441f7b237161a764b6bc38c075cda57" alt=""
|
4768 |
4768 |
|
|
4769 |
4769 |
Finally, we will sometimes use "Role Name of Entity 1 : Role Name of Entity 2" as a notation for the relation between them.
|
Finally, we will sometimes use "Role Name of Entity 1 : Role Name of Entity 2" as a notation for the relation between them.
|
4770 |
4770 |
For instance, we can write "Employer:Employee" to denote the "EMPLOYS" relation, and we will also use this notation when the relationship is between different entities, and write e.g. "PERSON:POSITION" for the "OCCUPIES" relation.
|
For instance, we can write "Employer:Employee" to denote the "EMPLOYS" relation, and we will also use this notation when the relationship is between different entities, and write e.g. "PERSON:POSITION" for the "OCCUPIES" relation.
|
|
... |
... |
STUDENT : TEAM | $M:N$ | "A student can participate in multiple team, a team can |
4793 |
4793 |
|
|
4794 |
4794 |
We indicate the ratio on the edges:
|
We indicate the ratio on the edges:
|
4795 |
4795 |
|
|
4796 |
|
data:image/s3,"s3://crabby-images/b573b/b573b4de623837797fbf43cb3e5b5eb47e1c6321" alt=""
|
|
|
4796 |
|
data:image/s3,"s3://crabby-images/af44d/af44dd7effda13c852a5d13b29fd91cb442b6e25" alt=""
|
4797 |
4797 |
|
|
4798 |
4798 |
Note that reflexive relations can have any ratio as well.
|
Note that reflexive relations can have any ratio as well.
|
4799 |
4799 |
An example of $M:N$ recursive relation could be:
|
An example of $M:N$ recursive relation could be:
|
4800 |
4800 |
|
|
4801 |
|
data:image/s3,"s3://crabby-images/02688/02688a2a6a3f15edf950b504d394c26b7c2dd07b" alt=""
|
|
|
4801 |
|
data:image/s3,"s3://crabby-images/b7191/b71913dfc3d3f8c22374f6096f6b0773a628ee58" alt=""
|
4802 |
4802 |
|
|
4803 |
4803 |
##### Participation Constraint
|
##### Participation Constraint
|
4804 |
4804 |
|
|
|
... |
... |
The participation can be total (a.k.a. existence dependency, the entity **must** |
4808 |
4808 |
|
|
4809 |
4809 |
Total is drawn with a double line, partial is drawn with a single line:
|
Total is drawn with a double line, partial is drawn with a single line:
|
4810 |
4810 |
|
|
4811 |
|
data:image/s3,"s3://crabby-images/310cd/310cdcd2908eee56723687c57b366130f0bdecf9" alt=""
|
|
|
4811 |
|
data:image/s3,"s3://crabby-images/7a7e9/7a7e9baee14231a9527fa79802a59b543ca14c70" alt=""
|
4812 |
4812 |
|
|
4813 |
4813 |
This reads "a course **must** be offered by a department, but a department may or may not offer courses".
|
This reads "a course **must** be offered by a department, but a department may or may not offer courses".
|
4814 |
4814 |
|
|
|
... |
... |
We are dealing with moving aspects here: atributes on $1:1$, $1:N$, $N:1$ relati |
4825 |
4825 |
|
|
4826 |
4826 |
For instance, imagine that every phone uses exactly (= "at most and at least") one carrier, that a carrier can provide network to multiple phones, and that the average quality of the network is an attribute in this relationship:
|
For instance, imagine that every phone uses exactly (= "at most and at least") one carrier, that a carrier can provide network to multiple phones, and that the average quality of the network is an attribute in this relationship:
|
4827 |
4827 |
|
|
4828 |
|
data:image/s3,"s3://crabby-images/71550/71550fd2c570c96924ddf40b55aa3703ab85dba9" alt=""
|
|
|
4828 |
|
data:image/s3,"s3://crabby-images/a9525/a9525bd5f888a4daa1830d68fa0dd0421eedebe8" alt=""
|
4829 |
4829 |
|
|
4830 |
4830 |
Then each instance of the relation would be of the form ("Phone X", "Carrier Y", "$9/10$") for some way of ranking the average quality from $0$ to $10$.
|
Then each instance of the relation would be of the form ("Phone X", "Carrier Y", "$9/10$") for some way of ranking the average quality from $0$ to $10$.
|
4831 |
4831 |
Note that, from the fact that the relationship is $N:1$, this means that there is only one tuple involving "Phone X": this means that the average quality could actually be seen as a property of _the phone_, and hence be migrated as an attribute to the phone side:
|
Note that, from the fact that the relationship is $N:1$, this means that there is only one tuple involving "Phone X": this means that the average quality could actually be seen as a property of _the phone_, and hence be migrated as an attribute to the phone side:
|
4832 |
4832 |
|
|
4833 |
|
data:image/s3,"s3://crabby-images/5c91a/5c91a736333c26866902955d257199088af1a9ac" alt=""
|
|
|
4833 |
|
data:image/s3,"s3://crabby-images/4a0bb/4a0bbbb5d64af98d6dd49950432f1e43b6ba2617" alt=""
|
4834 |
4834 |
|
|
4835 |
4835 |
Note that we could *not* migrate the "average phone quality" to the "Carrier" side: imagine if we had the instances ("Phone X", "Carrier Y", "$9/10$") and ("Phone Z", "Carrier Y", "$3/10$"), then should the attribute of "Carrier Y" be "$9/10$" or "$3/10$": we have no way of deciding based on this model.
|
Note that we could *not* migrate the "average phone quality" to the "Carrier" side: imagine if we had the instances ("Phone X", "Carrier Y", "$9/10$") and ("Phone Z", "Carrier Y", "$3/10$"), then should the attribute of "Carrier Y" be "$9/10$" or "$3/10$": we have no way of deciding based on this model.
|
4836 |
4836 |
|
|
|
... |
... |
As an exercise, you can look at the relationships TEACHING, MENTORING and EMITED |
4842 |
4842 |
Of course, relationships can have a degree higher than two.
|
Of course, relationships can have a degree higher than two.
|
4843 |
4843 |
An example of a ternary relation could be:
|
An example of a ternary relation could be:
|
4844 |
4844 |
|
|
4845 |
|
data:image/s3,"s3://crabby-images/aecc6/aecc60891911ac09b4842ddc776e7f625e739544" alt=""
|
|
|
4845 |
|
data:image/s3,"s3://crabby-images/527d1/527d1b6a4ad165cf909f02e54c1c5ab51dc7d1aa" alt=""
|
4846 |
4846 |
|
|
4847 |
4847 |
To determine cardinality ratio, one should fix all but one parameters, and wonder how many values of the remaining parameter can be in that relationship.
|
To determine cardinality ratio, one should fix all but one parameters, and wonder how many values of the remaining parameter can be in that relationship.
|
4848 |
4848 |
|
|
|
... |
... |
On the oppsite, Customer Y and Account K would be in relationship with only $1$ |
4852 |
4852 |
It is sometimes impossible to do without relations with arity greater than $2$.
|
It is sometimes impossible to do without relations with arity greater than $2$.
|
4853 |
4853 |
For instance, consider the following two diagrams:
|
For instance, consider the following two diagrams:
|
4854 |
4854 |
|
|
4855 |
|
data:image/s3,"s3://crabby-images/c61ba/c61badbb71798e0c38d7d1a899263a7e7728722d" alt=""
|
|
|
4855 |
|
data:image/s3,"s3://crabby-images/90b51/90b516cb4eadcd718380c1030c11e89c32c507fd" alt=""
|
4856 |
4856 |
|
|
4857 |
|
data:image/s3,"s3://crabby-images/0c6ed/0c6ed6f0095d0af61e20415ec598951b3f7b0cf9" alt=""
|
|
|
4857 |
|
data:image/s3,"s3://crabby-images/890ea/890ea6a32e25ac7aa5f0d0b02905725dd1da1fbb" alt=""
|
4858 |
4858 |
|
|
4859 |
4859 |
You should realize that they convey different information.
|
You should realize that they convey different information.
|
4860 |
4860 |
For instance, you can know for a fact that a person visit a library only if they bought something in it, while the second diagram de-correlate the act of buying with the visit to a library.
|
For instance, you can know for a fact that a person visit a library only if they bought something in it, while the second diagram de-correlate the act of buying with the visit to a library.
|
|
... |
... |
Similarly, the second diagram could give you a hint that a person that owns a co |
4862 |
4862 |
|
|
4863 |
4863 |
An example of recursive ternary relation could be:
|
An example of recursive ternary relation could be:
|
4864 |
4864 |
|
|
4865 |
|
data:image/s3,"s3://crabby-images/423f7/423f78f7768f8a5425e3ea6ddf18d884203f5df5" alt=""
|
|
|
4865 |
|
data:image/s3,"s3://crabby-images/16707/16707cb1d720d655869aa42fce39d9653bc3fa12" alt=""
|
4866 |
4866 |
|
|
4867 |
4867 |
An example of relation of degree $4$ could be:
|
An example of relation of degree $4$ could be:
|
4868 |
4868 |
|
|
4869 |
|
data:image/s3,"s3://crabby-images/dcef6/dcef62db198604f027a06260f6dc8f2e296648f5" alt=""
|
|
|
4869 |
|
data:image/s3,"s3://crabby-images/14675/14675602501f91c43acbbb4ed4e7dbf4b9596e1d" alt=""
|
4870 |
4870 |
|
|
4871 |
4871 |
|
|
4872 |
4872 |
---
|
---
|
|
... |
... |
The **partial key** is an attribute, that, _when paired with an entity with whic |
4885 |
4885 |
|
|
4886 |
4886 |
Weak entities and identifying relationships have a double border, and partial key have a dotted underline, as follows:
|
Weak entities and identifying relationships have a double border, and partial key have a dotted underline, as follows:
|
4887 |
4887 |
|
|
4888 |
|
data:image/s3,"s3://crabby-images/e6584/e658426e0d846b6997fb40b84802e16cc9d00fb3" alt=""
|
|
|
4888 |
|
data:image/s3,"s3://crabby-images/5cdf1/5cdf1955b909fbacaf681da92781b72e929c10e9" alt=""
|
4889 |
4889 |
|
|
4890 |
4890 |
The idea here is that we do not need to gather data about all the dependent in the world, or in isolation, but are interrested in dependent only if they are related to en employee in our database.
|
The idea here is that we do not need to gather data about all the dependent in the world, or in isolation, but are interrested in dependent only if they are related to en employee in our database.
|
4891 |
4891 |
Just having the name of a dependent is not enough to identify them, but having their name _and_ the SSN of the employee they are related to is enough.
|
Just having the name of a dependent is not enough to identify them, but having their name _and_ the SSN of the employee they are related to is enough.
|
|
... |
... |
If you need to have, for instance, a dependant connected to multiple employees, |
4895 |
4895 |
You may wonder why we do not represent weak entities simply as (composite, multi-valued) attributes of their owner type.
|
You may wonder why we do not represent weak entities simply as (composite, multi-valued) attributes of their owner type.
|
4896 |
4896 |
For instance, why would we use
|
For instance, why would we use
|
4897 |
4897 |
|
|
4898 |
|
data:image/s3,"s3://crabby-images/f6eff/f6efff43c103f9bd784291907d09937603a247d7" alt=""
|
|
|
4898 |
|
data:image/s3,"s3://crabby-images/40816/408165a8170cdfceab61fb316842d245c61f9682" alt=""
|
4899 |
4899 |
|
|
4900 |
4900 |
instead of
|
instead of
|
4901 |
4901 |
|
|
4902 |
|
data:image/s3,"s3://crabby-images/62117/62117535d38b27291c6a6a12e6068baa7a25f948" alt=""
|
|
|
4902 |
|
data:image/s3,"s3://crabby-images/b7827/b782794df08866c6954e3d6a9910e1d956af4f3c" alt=""
|
4903 |
4903 |
|
|
4904 |
4904 |
?
|
?
|
4905 |
4905 |
The answer depends whenever we need to have the ability to represent our weak entities (here, PET) as being in relationship with other entities (that can themselves be weak!), as follows:
|
The answer depends whenever we need to have the ability to represent our weak entities (here, PET) as being in relationship with other entities (that can themselves be weak!), as follows:
|
4906 |
4906 |
|
|
4907 |
|
data:image/s3,"s3://crabby-images/3c955/3c955635d294a426a43c8c5f1aa9171222dc8460" alt=""
|
|
|
4907 |
|
data:image/s3,"s3://crabby-images/8d244/8d244ff33bc1ad6a9499563139dcfd39fb11a546" alt=""
|
4908 |
4908 |
|
|
4909 |
4909 |
This would be impossible if PET was an attribute of FRIEND!
|
This would be impossible if PET was an attribute of FRIEND!
|
4910 |
4910 |
Whenever the pet entity type is involved in other relationships or not should help you in deciding which representation to chose.
|
Whenever the pet entity type is involved in other relationships or not should help you in deciding which representation to chose.
|
|
... |
... |
Whenever the pet entity type is involved in other relationships or not should he |
4915 |
4915 |
|
|
4916 |
4916 |
Another example of weak entity whose owner is weak as well could be:
|
Another example of weak entity whose owner is weak as well could be:
|
4917 |
4917 |
|
|
4918 |
|
data:image/s3,"s3://crabby-images/2a132/2a132e0b0cb2a15767049309efe927226edf7504" alt=""
|
|
|
4918 |
|
data:image/s3,"s3://crabby-images/7d57a/7d57a67bbe38bddb6eeb8747256bf8573ac80fc7" alt=""
|
4919 |
4919 |
|
|
4920 |
4920 |
The idea being that the Health care provider cares about an insuree only if they are covered by them, and that they care about the doula only if they are currently helping one of their insuree.
|
The idea being that the Health care provider cares about an insuree only if they are covered by them, and that they care about the doula only if they are currently helping one of their insuree.
|
4921 |
4921 |
|
|
|
... |
... |
The two constraints can be written on the same side, and the $N$, $M$, $P$ ratio |
4933 |
4933 |
|
|
4934 |
4934 |
For instance,
|
For instance,
|
4935 |
4935 |
|
|
4936 |
|
data:image/s3,"s3://crabby-images/1347e/1347e19634b6b36fdf4e92ba1bbcdccbcead86e4" alt=""
|
|
|
4936 |
|
data:image/s3,"s3://crabby-images/8778e/8778e127b9ff6e32ac1223dd0da668870bc48898" alt=""
|
4937 |
4937 |
|
|
4938 |
4938 |
could be drawn as
|
could be drawn as
|
4939 |
4939 |
|
|
4940 |
|
data:image/s3,"s3://crabby-images/919c5/919c59fde3f97f6af0e1899d4fbecbfd9e66c1f1" alt=""
|
|
|
4940 |
|
data:image/s3,"s3://crabby-images/a6ee8/a6ee84f1fb5572eb217a797fbf0bac3f5ca2f6a8" alt=""
|
4941 |
4941 |
|
|
4942 |
4942 |
meaning that
|
meaning that
|
4943 |
4943 |
|
|
|
... |
... |
meaning that |
4946 |
4946 |
|
|
4947 |
4947 |
More generally, we have the following:
|
More generally, we have the following:
|
4948 |
4948 |
|
|
4949 |
|
data:image/s3,"s3://crabby-images/ea094/ea09415d3556b51be6fbe82dd1859bd4ee75e981" alt=""
|
|
|
4949 |
|
data:image/s3,"s3://crabby-images/c11f1/c11f1b1d14a452beeec75d370fa85126fa2f87a2" alt=""
|
4950 |
4950 |
|
|
4951 |
4951 |
#### Crow's Foot Notation {#sec:Crow_foot}
|
#### Crow's Foot Notation {#sec:Crow_foot}
|
4952 |
4952 |
|
|
|
... |
... |
Every time a relationships have attributes, they are mapped to the resulting rel |
5029 |
5029 |
Let us look in more details at some of those steps.
|
Let us look in more details at some of those steps.
|
5030 |
5030 |
For strong entities, using steps 1 and 7, the following:
|
For strong entities, using steps 1 and 7, the following:
|
5031 |
5031 |
|
|
5032 |
|
data:image/s3,"s3://crabby-images/31a2e/31a2e0e0fb758ea2b83a179d274160b3f92197a3" alt=""
|
|
|
5032 |
|
data:image/s3,"s3://crabby-images/dfb9e/dfb9e1550084a33e347d330cc78a82da2e0d45ca" alt=""
|
5033 |
5033 |
|
|
5034 |
5034 |
would give:
|
would give:
|
5035 |
5035 |
|
|
5036 |
5036 |
data:image/s3,"s3://crabby-images/652d2/652d265e8a9c78109de0d1c82ce68d6b3cb2586d" alt="
|
![
|
5037 |
5037 |
DESK(Serial(PK), Building, Room)
|
DESK(Serial(PK), Building, Room)
|
5038 |
5038 |
DESK_COLOR(Desk (PK, FK referencing DESK.Serial))
|
DESK_COLOR(Desk (PK, FK referencing DESK.Serial))
|
5039 |
|
"
|
|
|
5039 |
|
](fig/rel_mod/desk)
|
5040 |
5040 |
\
|
\
|
5041 |
5041 |
|
|
5042 |
5042 |
|
|
5043 |
5043 |
And note that if Serial was a complex attribute, we would just "unfold" it, or decompose it, and make all the resulting attributes the primary key of the relation.
|
And note that if Serial was a complex attribute, we would just "unfold" it, or decompose it, and make all the resulting attributes the primary key of the relation.
|
5044 |
5044 |
If one of the attribute was at the same time multi-valued and composite, as follows:
|
If one of the attribute was at the same time multi-valued and composite, as follows:
|
5045 |
5045 |
|
|
5046 |
|
data:image/s3,"s3://crabby-images/fc7f9/fc7f99f3a25620a920b688f435a2db0533df280b" alt=""
|
|
|
5046 |
|
data:image/s3,"s3://crabby-images/2b26f/2b26f97b08caf9f2a857056c013faa49354ad7b5" alt=""
|
5047 |
5047 |
|
|
5048 |
5048 |
Then we would obtain:
|
Then we would obtain:
|
5049 |
5049 |
|
|
5050 |
5050 |
data:image/s3,"s3://crabby-images/a8093/a80937a94f69637997cf1ce76f6cdc330ed052e8" alt="
|
![
|
5051 |
5051 |
COMPUTER(MAC(PK))
|
COMPUTER(MAC(PK))
|
5052 |
5052 |
COMPUTER_COLOR(Compter (PK, FK referencing COMPUTER.MAC), Name, Email)
|
COMPUTER_COLOR(Compter (PK, FK referencing COMPUTER.MAC), Name, Email)
|
5053 |
|
"
|
|
|
5053 |
|
](fig/rel_mod/computer_user)
|
5054 |
5054 |
\
|
\
|
5055 |
5055 |
|
|
5056 |
5056 |
For relationships, things are a bit more complicated.
|
For relationships, things are a bit more complicated.
|
5057 |
5057 |
Consider the following:
|
Consider the following:
|
5058 |
5058 |
|
|
5059 |
|
data:image/s3,"s3://crabby-images/5d39d/5d39dcec5a9123e64a0d00444d549000fb12417f" alt=""
|
|
|
5059 |
|
data:image/s3,"s3://crabby-images/3530a/3530a246f8f7c7fcf07251589a37e3a6ccf9cabf" alt=""
|
5060 |
5060 |
|
|
5061 |
5061 |
Since it is a $1:1$ relationship where one of the side has a partial constraint, we have the choice between two approaches.
|
Since it is a $1:1$ relationship where one of the side has a partial constraint, we have the choice between two approaches.
|
5062 |
5062 |
The foreign key approach would give:
|
The foreign key approach would give:
|
|
... |
... |
The foreign key approach would give: |
5064 |
5064 |
data:image/s3,"s3://crabby-images/123e9/123e922b5fa3ba235b23d4f14e56da739905fa76" alt="
|
![
|
5065 |
5065 |
ENT.A(KeyA (PK), FK (FK to ENT.B.KeyB))
|
ENT.A(KeyA (PK), FK (FK to ENT.B.KeyB))
|
5066 |
5066 |
ENT.B(KeyB (PK))
|
ENT.B(KeyB (PK))
|
5067 |
|
"
|
|
|
5067 |
|
](fig/rel_mod/mapping_relationships_01)
|
5068 |
5068 |
\
|
\
|
5069 |
5069 |
|
|
5070 |
5070 |
Note that we could also have added the foreign key on the side of ENT.B, referencing the key of ENT.A.
|
Note that we could also have added the foreign key on the side of ENT.B, referencing the key of ENT.A.
|
|
... |
... |
For the same diagram, the cross-reference approach would give: |
5076 |
5076 |
ENT.A(KeyA (PK))
|
ENT.A(KeyA (PK))
|
5077 |
5077 |
ENT.B(KeyB (PK))
|
ENT.B(KeyB (PK))
|
5078 |
5078 |
MAPPING(KeyA (PK, FK referencing ENT.A.KeyA), KeyB(FK referencing ENT.B.KeyB))
|
MAPPING(KeyA (PK, FK referencing ENT.A.KeyA), KeyB(FK referencing ENT.B.KeyB))
|
5079 |
|
](fig/rel_mod/MappingRelationships2)
|
|
|
5079 |
|
](fig/rel_mod/mapping_relationships_02)
|
5080 |
5080 |
\
|
\
|
5081 |
5081 |
|
|
5082 |
5082 |
Similarly, note that, in MAPPING, KeyB, or KeyA and KeyB, would also be valid primary keys, but that it makes more sense to have KeyA being the primary key, since we know that ENT.A has a total participation constraint, but ENT.B does not.
|
Similarly, note that, in MAPPING, KeyB, or KeyA and KeyB, would also be valid primary keys, but that it makes more sense to have KeyA being the primary key, since we know that ENT.A has a total participation constraint, but ENT.B does not.
|
5083 |
5083 |
|
|
5084 |
5084 |
If both participation constraints were total, as follows:
|
If both participation constraints were total, as follows:
|
5085 |
5085 |
|
|
5086 |
|
data:image/s3,"s3://crabby-images/644f5/644f59f3deb257b59dc257fb7d34f8ae2fdc0a85" alt=""
|
|
|
5086 |
|
data:image/s3,"s3://crabby-images/a7ecc/a7ecc5f78d600b986eed6a77055e7d36e2e57920" alt=""
|
5087 |
5087 |
|
|
5088 |
5088 |
Then we could use the merged relations approach, and get:
|
Then we could use the merged relations approach, and get:
|
5089 |
5089 |
|
|
5090 |
5090 |
data:image/s3,"s3://crabby-images/18ea7/18ea7b6e417cda0efbb34d32089f561146f80638" alt="
|
![
|
5091 |
5091 |
ENT.A.AND.B.(KeyA (PK), KeyB)
|
ENT.A.AND.B.(KeyA (PK), KeyB)
|
5092 |
|
"
|
|
|
5092 |
|
](fig/rel_mod/mapping_relationships_03)
|
5093 |
5093 |
\
|
\
|
5094 |
5094 |
|
|
5095 |
5095 |
We picked KeyA to be the primary key for the same reason as before.
|
We picked KeyA to be the primary key for the same reason as before.
|
|
... |
... |
Of course, if ENT.A and ENT.B are the same entity (that is, REL is recursive), w |
5099 |
5099 |
|
|
5100 |
5100 |
data:image/s3,"s3://crabby-images/1c741/1c741cc4ca0b41299e03af51f5762ec86ea71ab9" alt="
|
![
|
5101 |
5101 |
ENT.A(KeyA (PK), Rel(FK referencing Ent.A.KeyA))
|
ENT.A(KeyA (PK), Rel(FK referencing Ent.A.KeyA))
|
5102 |
|
"
|
|
|
5102 |
|
](fig/rel_mod/mapping_relationships_04)
|
5103 |
5103 |
\
|
\
|
5104 |
5104 |
|
|
5105 |
5105 |
or
|
or
|
|
... |
... |
or |
5107 |
5107 |
data:image/s3,"s3://crabby-images/bb78d/bb78d3e7e70c5af454c10d8a91e855827f571bdd" alt="
|
![
|
5108 |
5108 |
ENT.A(KeyA (PK))
|
ENT.A(KeyA (PK))
|
5109 |
5109 |
REL(KeyA1 (PK, FK referencing Ent.A.KeyA), KeyA2 (FK referencing Ent.A.KeyA))
|
REL(KeyA1 (PK, FK referencing Ent.A.KeyA), KeyA2 (FK referencing Ent.A.KeyA))
|
5110 |
|
"
|
|
|
5110 |
|
](fig/rel_mod/mapping_relationships_05)
|
5111 |
5111 |
\
|
\
|
5112 |
5112 |
|
|
5113 |
5113 |
depending on the approach we chose.
|
depending on the approach we chose.
|
|
... |
... |
Binary $1:N$ and binary $M:N$ relationships are dealt with in a similar way, usi |
5116 |
5116 |
The most difficult part of the mapping is with $n$-ary relationships: we have to use cross-reference approaches, but determining the primary key is not an easy task.
|
The most difficult part of the mapping is with $n$-ary relationships: we have to use cross-reference approaches, but determining the primary key is not an easy task.
|
5117 |
5117 |
Consider the following^[This developement was actually asked at <https://dba.stackexchange.com/q/232068/>.]:
|
Consider the following^[This developement was actually asked at <https://dba.stackexchange.com/q/232068/>.]:
|
5118 |
5118 |
|
|
5119 |
|
data:image/s3,"s3://crabby-images/28ad4/28ad46b28a2c36d0b2fa9178b224bf4a7cc1e5ec" alt=""
|
|
|
5119 |
|
data:image/s3,"s3://crabby-images/5b582/5b5826803ddebf8139062382dbc9ba1277488620" alt=""
|
5120 |
5120 |
|
|
5121 |
5121 |
The arity constraints here can be rephrased as:
|
The arity constraints here can be rephrased as:
|
5122 |
5122 |
|
|
|
... |
... |
Att. 1 → Att. 3 | Att. 2 → Att. 1 |
5290 |
5290 |
|
|
5291 |
5291 |
#### Notations
|
#### Notations
|
5292 |
5292 |
|
|
5293 |
|
data:image/s3,"s3://crabby-images/36dcf/36dcfc464184a7c0d4c189dd5279a39cc6f75039" alt=""
|
|
|
5293 |
|
data:image/s3,"s3://crabby-images/ff8a7/ff8a73ffc42bdd60a7a2d64e28163a6546642de0" alt=""
|
5294 |
5294 |
|
|
5295 |
5295 |
Or, more conveniently:
|
Or, more conveniently:
|
5296 |
5296 |
|
|
5297 |
|
data:image/s3,"s3://crabby-images/75bb8/75bb87b66f1c453b1b36b0ab2689669bdb411602" alt=""
|
|
|
5297 |
|
data:image/s3,"s3://crabby-images/12172/12172e5cbdec2faeb3795319729a31d836031e2d" alt=""
|
5298 |
5298 |
|
|
5299 |
5299 |
If an attribute is a foreign key to another, we will draw an arrow between relations:
|
If an attribute is a foreign key to another, we will draw an arrow between relations:
|
5300 |
5300 |
|
|
5301 |
|
data:image/s3,"s3://crabby-images/2fc77/2fc77e4d02e5faa24802c273cbef3755f84b7094" alt=""
|
|
|
5301 |
|
data:image/s3,"s3://crabby-images/0cb86/0cb86b11667e729c1c3b93910e927cd4a6d02d0c" alt=""
|
5302 |
5302 |
|
|
5303 |
5303 |
Note that:
|
Note that:
|
5304 |
5304 |
|
|
|
... |
... |
For each attribute $A$ of the relation whose primary key is $A_1, …, A_n$: |
5386 |
5386 |
- Remove $A$ from the original relation, and all the functional dependencies that implied it,
|
- Remove $A$ from the original relation, and all the functional dependencies that implied it,
|
5387 |
5387 |
- Add a foreign key from $\{A'_1, …, A'_k\}$ to their original counterparts in the original relation.
|
- Add a foreign key from $\{A'_1, …, A'_k\}$ to their original counterparts in the original relation.
|
5388 |
5388 |
|
|
5389 |
|
data:image/s3,"s3://crabby-images/15279/15279bb90f7a555f1c9af53903c224000602a0bb" alt=""
|
|
|
5389 |
|
data:image/s3,"s3://crabby-images/72001/72001f6e94e9762a752c19b99efafd78dcdf7032" alt=""
|
5390 |
5390 |
|
|
5391 |
5391 |
becomes
|
becomes
|
5392 |
5392 |
|
|
5393 |
|
data:image/s3,"s3://crabby-images/86f78/86f780c1ef5f9a9cfac3c967319b37aa693d87ca" alt=""
|
|
|
5393 |
|
data:image/s3,"s3://crabby-images/f0ca1/f0ca1bd167c8d0b4568f2c258b6cbc0e26d720eb" alt=""
|
5394 |
5394 |
|
|
5395 |
5395 |
|
|
5396 |
5396 |
Refinment: note that if more than one attribute depends of the same subset $\{A'_1, …, A'_k\}$, we will create two relations: that is useless, we could have created just one.
|
Refinment: note that if more than one attribute depends of the same subset $\{A'_1, …, A'_k\}$, we will create two relations: that is useless, we could have created just one.
|
5397 |
5397 |
For instance, considering
|
For instance, considering
|
5398 |
5398 |
|
|
5399 |
|
data:image/s3,"s3://crabby-images/327d8/327d851eb587192e672faa636559f86d2839df18" alt=""
|
|
|
5399 |
|
data:image/s3,"s3://crabby-images/05568/055680bad66f0e7ad0e78481d96eb91a44cffba4" alt=""
|
5400 |
5400 |
|
|
5401 |
5401 |
applying the algorithm would give
|
applying the algorithm would give
|
5402 |
5402 |
|
|
5403 |
|
data:image/s3,"s3://crabby-images/f88c4/f88c40b4a12754df18063fc76384be42b9342ab8" alt=""
|
|
|
5403 |
|
data:image/s3,"s3://crabby-images/6ca5e/6ca5ec281803c7c3cdcccfc85e01b9e95b82c2e5" alt=""
|
5404 |
5404 |
|
|
5405 |
5405 |
whereas a more subtle algorithm would give
|
whereas a more subtle algorithm would give
|
5406 |
5406 |
|
|
5407 |
|
data:image/s3,"s3://crabby-images/4b12e/4b12e1e30b5cff50e6808b89c80401c090069977" alt=""
|
|
|
5407 |
|
data:image/s3,"s3://crabby-images/35db4/35db464b3d28f1a7231a8b303040847964623213" alt=""
|
5408 |
5408 |
|
|
5409 |
5409 |
Note that in both cases, all the relations are in Second Normal Form, though.
|
Note that in both cases, all the relations are in Second Normal Form, though.
|
5410 |
5410 |
|
|
|
... |
... |
For each attribute $A$ of the relation whose primary key is $A_1, …, A_n$: |
5435 |
5435 |
|
|
5436 |
5436 |
We can have a look at another example:
|
We can have a look at another example:
|
5437 |
5437 |
|
|
5438 |
|
data:image/s3,"s3://crabby-images/c602f/c602f19ae7786aea68f6a12c908099e789fda8e4" alt=""
|
|
|
5438 |
|
data:image/s3,"s3://crabby-images/fc3fa/fc3fa6defe9b77ba5af66a525ca4b8feb7635056" alt=""
|
5439 |
5439 |
|
|
5440 |
5440 |
Note that \{State, Driver\_Licence\_Num\}, would be a valid primary key for this relation, and that adding it would make it a relation in 1NF.
|
Note that \{State, Driver\_Licence\_Num\}, would be a valid primary key for this relation, and that adding it would make it a relation in 1NF.
|
5441 |
5441 |
|
|
|
... |
... |
As we can see, the name "Driver" is somehow counter-intuitive, since the relatio |
5443 |
5443 |
This relation is actually not in 2NF, because the FD \{State, Driver\_Licence\_Num\} → Governor is not fully functional.
|
This relation is actually not in 2NF, because the FD \{State, Driver\_Licence\_Num\} → Governor is not fully functional.
|
5444 |
5444 |
A possible way to fix it is to get:
|
A possible way to fix it is to get:
|
5445 |
5445 |
|
|
5446 |
|
data:image/s3,"s3://crabby-images/54147/541471dabfafe95d1b6b2d709f8b80a2815003ae" alt=""
|
|
|
5446 |
|
data:image/s3,"s3://crabby-images/d3141/d3141bc9c2586f97dbdb30237fad794a9c4d64cc" alt=""
|
5447 |
5447 |
|
|
5448 |
5448 |
As you can see, the 2NF helped us in separating properly the entities.
|
As you can see, the 2NF helped us in separating properly the entities.
|
5449 |
5449 |
|
|
5450 |
5450 |
An example of a relation that is in 2NF but not in 3NF could be:
|
An example of a relation that is in 2NF but not in 3NF could be:
|
5451 |
5451 |
|
|
5452 |
|
data:image/s3,"s3://crabby-images/59911/59911f96303ab50a81000e1824e9b13021d502b3" alt=""
|
|
|
5452 |
|
data:image/s3,"s3://crabby-images/a4390/a439072a9a36c88d4ab5b6a8cae314df2b8bf268" alt=""
|
5453 |
5453 |
|
|
5454 |
5454 |
As we can see, all the non-prime attributes are fully functionaly dependent from Login, which is our primary key.
|
As we can see, all the non-prime attributes are fully functionaly dependent from Login, which is our primary key.
|
5455 |
5455 |
But, obviously, one of this dependecy is transitive, and breaks the 3NF.
|
But, obviously, one of this dependecy is transitive, and breaks the 3NF.
|
5456 |
5456 |
A way to fix it is:
|
A way to fix it is:
|
5457 |
5457 |
|
|
5458 |
|
data:image/s3,"s3://crabby-images/ab3a1/ab3a12ce437f423d747a05a78f62b0f1af59aa60" alt=""
|
|
|
5458 |
|
data:image/s3,"s3://crabby-images/eebfd/eebfd9847382c0e855447277521b541cf4862d8d" alt=""
|
5459 |
5459 |
|
|
5460 |
5460 |
As we can see, 3NF also helped us in separating properly the entities, in a slightly different way.
|
As we can see, 3NF also helped us in separating properly the entities, in a slightly different way.
|
5461 |
5461 |
|
|
|
... |
... |
Would it make sense to be have a total participation constraint on one side, and |
5651 |
5651 |
Exercise +.#
|
Exercise +.#
|
5652 |
5652 |
|
|
5653 |
5653 |
: Express the constraints represented in the following diagram in plain English.
|
: Express the constraints represented in the following diagram in plain English.
|
5654 |
|
data:image/s3,"s3://crabby-images/634e7/634e726061c970228c10d977be2f4f21b15e578c" alt=""
|
|
|
5654 |
|
data:image/s3,"s3://crabby-images/82fc5/82fc50a35e252b133cb5fae357cce0308467328c" alt=""
|
5655 |
5655 |
|
|
5656 |
5656 |
Exercise +.#
|
Exercise +.#
|
5657 |
5657 |
|
|
|
... |
... |
Exercise +.# |
5726 |
5726 |
~
|
~
|
5727 |
5727 |
Convert the following ER diagram into a relational model:
|
Convert the following ER diagram into a relational model:
|
5728 |
5728 |
|
|
5729 |
|
data:image/s3,"s3://crabby-images/25460/25460781b0f828bd82dc4f1a1e1ff2a418f9fca8" alt=""
|
|
|
5729 |
|
data:image/s3,"s3://crabby-images/41bac/41bac72ed8bfd4768ec0f22789d57d9755a866e9" alt=""
|
5730 |
5730 |
|
|
5731 |
5731 |
Exercise +.#
|
Exercise +.#
|
5732 |
5732 |
|
|
|
... |
... |
Exercise +.# |
5877 |
5877 |
~
|
~
|
5878 |
5878 |
Consider the following diagram:
|
Consider the following diagram:
|
5879 |
5879 |
|
|
5880 |
|
data:image/s3,"s3://crabby-images/893ca/893ca66c575558ea2179686db259a62e4a694395" alt=""
|
|
|
5880 |
|
data:image/s3,"s3://crabby-images/e861d/e861d03bb1b6e77fc1ceae82884b85298590f4f6" alt=""
|
5881 |
5881 |
|
|
5882 |
5882 |
Give the number of attributes for both classes, and suggest two operations for the class that does not have any. Discuss the multiplicities: why did the designer picked those values?
|
Give the number of attributes for both classes, and suggest two operations for the class that does not have any. Discuss the multiplicities: why did the designer picked those values?
|
5883 |
5883 |
|
|
|
... |
... |
Exercise +.# |
5885 |
5885 |
~
|
~
|
5886 |
5886 |
Convert the following E.R. diagram to a U.M.L. class diagram.
|
Convert the following E.R. diagram to a U.M.L. class diagram.
|
5887 |
5887 |
|
|
5888 |
|
: data:image/s3,"s3://crabby-images/5e7d9/5e7d9f682e1796d78a8479bd789dd20794ca6438" alt=""
|
|
|
5888 |
|
: data:image/s3,"s3://crabby-images/e6010/e601010ed39d080ec7a93b81e51e6b2cada39485" alt=""
|
5889 |
5889 |
|
|
5890 |
5890 |
Exercise +.#
|
Exercise +.#
|
5891 |
5891 |
|
|
|
... |
... |
Exercise +.# |
5901 |
5901 |
|
|
5902 |
5902 |
Convert the following E.R. diagram into a U.M.L. class diagram:
|
Convert the following E.R. diagram into a U.M.L. class diagram:
|
5903 |
5903 |
|
|
5904 |
|
data:image/s3,"s3://crabby-images/691c8/691c8c5a0807e306947ece3f2762d16fac356af8" alt=""
|
|
|
5904 |
|
data:image/s3,"s3://crabby-images/6e161/6e1614c208abcf929351d6fc4c7e2e833b921396" alt=""
|
5905 |
5905 |
|
|
5906 |
5906 |
|
|
5907 |
5907 |
## Solution to Exercises {-}
|
## Solution to Exercises {-}
|
|
... |
... |
To have statistics about the extensions, to sort the username by length, etc. |
5917 |
5917 |
|
|
5918 |
5918 |
Solution +.#
|
Solution +.#
|
5919 |
5919 |
|
|
5920 |
|
: data:image/s3,"s3://crabby-images/9b6f8/9b6f8613d9b293d6cf6cb647354235af8f33ab19" alt=""
|
|
|
5920 |
|
: data:image/s3,"s3://crabby-images/33466/33466cb7f4637069684f731b335221ea964ed1b3" alt=""
|
5921 |
5921 |
|
|
5922 |
5922 |
Solution +.#
|
Solution +.#
|
5923 |
5923 |
|
|
5924 |
|
: data:image/s3,"s3://crabby-images/3bd2c/3bd2c488b69d4d0a7f02cfbbb40f29ee77785d28" alt=""
|
|
|
5924 |
|
: data:image/s3,"s3://crabby-images/80710/8071024420c009084999841342f57632082c4aed" alt=""
|
5925 |
5925 |
|
|
5926 |
5926 |
Solution +.#
|
Solution +.#
|
5927 |
5927 |
|
|
|
... |
... |
Solution +.# |
5929 |
5929 |
|
|
5930 |
5930 |
Solution +.#
|
Solution +.#
|
5931 |
5931 |
|
|
5932 |
|
: data:image/s3,"s3://crabby-images/76535/76535a913da58d1f4c9a82d7621080daba5f58e2" alt=""
|
|
|
5932 |
|
: data:image/s3,"s3://crabby-images/8e33c/8e33cf22ea195a4048b5bcd9fe9830b23c940f66" alt=""
|
5933 |
5933 |
|
|
5934 |
5934 |
Solution +.#
|
Solution +.#
|
5935 |
5935 |
|
|
|
... |
... |
Solution +.# |
5983 |
5983 |
|
|
5984 |
5984 |
Solution +.#
|
Solution +.#
|
5985 |
5985 |
|
|
5986 |
|
: data:image/s3,"s3://crabby-images/5e7d9/5e7d9f682e1796d78a8479bd789dd20794ca6438" alt=""
|
|
|
5986 |
|
: data:image/s3,"s3://crabby-images/e6010/e601010ed39d080ec7a93b81e51e6b2cada39485" alt=""
|
5987 |
5987 |
|
|
5988 |
5988 |
Solution +.#
|
Solution +.#
|
5989 |
5989 |
|
|
|
... |
... |
Solution +.# |
5992 |
5992 |
|
|
5993 |
5993 |
Solution +.#
|
Solution +.#
|
5994 |
5994 |
|
|
5995 |
|
: data:image/s3,"s3://crabby-images/222d7/222d7c347ba03347a07595fd9e529a05ae5e579c" alt=""
|
|
|
5995 |
|
: data:image/s3,"s3://crabby-images/9edc2/9edc2f2bdb8150d34e5d621018787679539dc153" alt=""
|
5996 |
5996 |
|
|
5997 |
5997 |
Solution +.#
|
Solution +.#
|
5998 |
5998 |
|
|
5999 |
|
: data:image/s3,"s3://crabby-images/b4c6c/b4c6c5f5b24781f017566886f103584c2b7060f5" alt=""
|
|
|
5999 |
|
: data:image/s3,"s3://crabby-images/043cc/043cccf507d430f3f30fd7e8b10b2602e2566d02" alt=""
|
6000 |
6000 |
|
|
6001 |
6001 |
Solution +.#
|
Solution +.#
|
6002 |
6002 |
|
|
|
... |
... |
Solution +.# |
6009 |
6009 |
|
|
6010 |
6010 |
We could have the following:
|
We could have the following:
|
6011 |
6011 |
|
|
6012 |
|
data:image/s3,"s3://crabby-images/1bd44/1bd4464295c63458c2404e4c00e27f8a328b05fc" alt=""
|
|
|
6012 |
|
data:image/s3,"s3://crabby-images/ca604/ca604558b563bf9daca17a51b682c688aa5b40b0" alt=""
|
6013 |
6013 |
|
|
6014 |
6014 |
Solution +.#
|
Solution +.#
|
6015 |
6015 |
~
|
~
|
6016 |
6016 |
|
|
6017 |
6017 |
We could have the following:
|
We could have the following:
|
6018 |
6018 |
|
|
6019 |
|
data:image/s3,"s3://crabby-images/ec69f/ec69fc5146fffb1282dbd4a3658ebda38cb523e2" alt=""
|
|
|
6019 |
|
data:image/s3,"s3://crabby-images/a5f38/a5f3873e43d1c85ba2611994367784ab3eb9564f" alt=""
|
6020 |
6020 |
|
|
6021 |
6021 |
Solution +.#
|
Solution +.#
|
6022 |
6022 |
|
|
|
... |
... |
Solution +.# |
6041 |
6041 |
|
|
6042 |
6042 |
A possible solution is:
|
A possible solution is:
|
6043 |
6043 |
|
|
6044 |
|
data:image/s3,"s3://crabby-images/361f5/361f58b728fd1c1b85008b3d16b2520c7357be11" alt=""
|
|
|
6044 |
|
data:image/s3,"s3://crabby-images/29fbf/29fbfd8a7748422de186db58f481ae7797cafef2" alt=""
|
6045 |
6045 |
|
|
6046 |
6046 |
Note that the two composite attributes are "generic", in the sense that you can re-use those examples easily.
|
Note that the two composite attributes are "generic", in the sense that you can re-use those examples easily.
|
6047 |
6047 |
|
|
|
... |
... |
Solution +.# |
6055 |
6055 |
data:image/s3,"s3://crabby-images/dbb07/dbb074abc0a515a881a1a5f3c9e205d4b3dded3a" alt="
|
![
|
6056 |
6056 |
PERSON(SSN (PK), DOB, Stays_At (FK to PLACE.Address)
|
PERSON(SSN (PK), DOB, Stays_At (FK to PLACE.Address)
|
6057 |
6057 |
ADDRESS(Address (PK), Rooms)
|
ADDRESS(Address (PK), Rooms)
|
6058 |
|
"
|
|
|
6058 |
|
](fig/rel_mod/person)
|
6059 |
6059 |
\
|
\
|
6060 |
6060 |
|
|
6061 |
6061 |
Note that "Stays_At" could also be a separate relation, with two attributes, "Address" and "Person", linked to respectively PLACE.Address and PERSON.SSN, and both being the primary key of the relation.
|
Note that "Stays_At" could also be a separate relation, with two attributes, "Address" and "Person", linked to respectively PLACE.Address and PERSON.SSN, and both being the primary key of the relation.
|
|
... |
... |
Problem (Reverse engineering by hand) +.#Reverse-Engineering-ACTOR |
6293 |
6293 |
|
|
6294 |
6294 |
Look at the following relational model, and "reverse-engineer" it to obtain an E.R. diagram:
|
Look at the following relational model, and "reverse-engineer" it to obtain an E.R. diagram:
|
6295 |
6295 |
|
|
6296 |
|
data:image/s3,"s3://crabby-images/24d71/24d71df9d1922532884a348a2474ac3982904ec8" alt=""
|
|
|
6296 |
|
data:image/s3,"s3://crabby-images/7020a/7020a6ec5a73f314b6625b7a58c7faccf0a63ea4" alt=""
|
6297 |
6297 |
|
|
6298 |
6298 |
---
|
---
|
6299 |
6299 |
|
|
|
... |
... |
Problem (From E.R. diagram to Relational model -- BIKE) +.#ERtoRELBike |
6330 |
6330 |
|
|
6331 |
6331 |
Consider the following E.R. diagram:
|
Consider the following E.R. diagram:
|
6332 |
6332 |
|
|
6333 |
|
data:image/s3,"s3://crabby-images/79d7c/79d7c007f32aa450a621f95adfdf51d8f70fdf0a" alt=""
|
|
|
6333 |
|
data:image/s3,"s3://crabby-images/af029/af029f2b45a5d5f6b7abdac0cfb3771d5d3b9946" alt=""
|
6334 |
6334 |
\
|
\
|
6335 |
6335 |
|
|
6336 |
6336 |
_Based on this diagram_, answer the following: "Is it true that …"
|
_Based on this diagram_, answer the following: "Is it true that …"
|
|
... |
... |
Problem (From E.R. diagram to Relational model -- RECORD) +.#ERtoRELRecord |
6356 |
6356 |
|
|
6357 |
6357 |
Consider the following E.R. diagram:
|
Consider the following E.R. diagram:
|
6358 |
6358 |
|
|
6359 |
|
data:image/s3,"s3://crabby-images/69780/697805cd2fa6c9966552c7b44a3b70d2d993a24b" alt=""
|
|
|
6359 |
|
data:image/s3,"s3://crabby-images/870c7/870c7c81e7eda93fd41ccd710106c47c5da4ffde" alt=""
|
6360 |
6360 |
\
|
\
|
6361 |
6361 |
|
|
6362 |
6362 |
_Based on this diagram_, is it true that …
|
_Based on this diagram_, is it true that …
|
|
... |
... |
Problem (ER-to-Relation mapping for Country) +.#ERtoRELCountry |
6382 |
6382 |
|
|
6383 |
6383 |
Consider the following E.R. schema:
|
Consider the following E.R. schema:
|
6384 |
6384 |
|
|
6385 |
|
data:image/s3,"s3://crabby-images/ab22b/ab22b9c1201124f227ab36b8be05173c5236facd" alt=""
|
|
|
6385 |
|
data:image/s3,"s3://crabby-images/7ef16/7ef16a1858dc6f48e7dec4cf40e1de85faa335c5" alt=""
|
6386 |
6386 |
\
|
\
|
6387 |
6387 |
|
|
6388 |
6388 |
where
|
where
|
|
... |
... |
Problem (PRINT relation in third normal form) +.#print |
6657 |
6657 |
|
|
6658 |
6658 |
Normalize the following relation to the third normal form.
|
Normalize the following relation to the third normal form.
|
6659 |
6659 |
|
|
6660 |
|
data:image/s3,"s3://crabby-images/f1b81/f1b81dfe2e75976a54db204cbbe42a1aa3491927" alt=""{width=90%}
|
|
|
6660 |
|
data:image/s3,"s3://crabby-images/e8400/e84008b2f5fae0a7eb9a10e5334f4ac3a77f86e6" alt=""{width=90%}
|
6661 |
6661 |
|
|
6662 |
6662 |
Do not forget to indicate all the primary keys in your relations.
|
Do not forget to indicate all the primary keys in your relations.
|
6663 |
6663 |
|
|
|
... |
... |
Problem (From E.R. to relational schema and UML class diagram -- CAR\_INFO) +.#c |
6732 |
6732 |
|
|
6733 |
6733 |
Consider the following E.R. schema for the CAR\_INFO database:
|
Consider the following E.R. schema for the CAR\_INFO database:
|
6734 |
6734 |
|
|
6735 |
|
data:image/s3,"s3://crabby-images/37a6f/37a6f9d74d592d86c06fe429e3365df8f03058b9" alt=""
|
|
|
6735 |
|
data:image/s3,"s3://crabby-images/53219/53219d9be9cd4e7ee31ed9fceca4b1c4108ada2f" alt=""
|
6736 |
6736 |
|
|
6737 |
6737 |
Note that a car can have at most one driver, $N$ passengers, $N$ insurances, and that car insurances exist only if they are "tied up" to a car (i.e., they are weak entities, and their identifying relationship is called "Insured").
|
Note that a car can have at most one driver, $N$ passengers, $N$ insurances, and that car insurances exist only if they are "tied up" to a car (i.e., they are weak entities, and their identifying relationship is called "Insured").
|
6738 |
6738 |
|
|
|
... |
... |
Solution to [%D %n (%T)](#problem:car-insurance) |
6833 |
6833 |
|
|
6834 |
6834 |
and
|
and
|
6835 |
6835 |
|
|
6836 |
|
data:image/s3,"s3://crabby-images/dd732/dd7323de8febd372e1ea81c1e965c348cbe063a4" alt=""
|
|
|
6836 |
|
data:image/s3,"s3://crabby-images/b34b5/b34b5d1d30229e41d28f1b268a3a938f1f0de5ee" alt=""
|
6837 |
6837 |
\
|
\
|
6838 |
6838 |
|
|
6839 |
6839 |
---
|
---
|
|
... |
... |
Solution to [%D %n (%T)](#problem:job-offers) |
6843 |
6843 |
|
|
6844 |
6844 |
A possible solution is:
|
A possible solution is:
|
6845 |
6845 |
|
|
6846 |
|
data:image/s3,"s3://crabby-images/aadfc/aadfcf992925d2e83b7eb0edd12ba8cb68799db9" alt=""
|
|
|
6846 |
|
data:image/s3,"s3://crabby-images/8932c/8932c47571cf1d7f842d938656d3844bdefea9fb" alt=""
|
6847 |
6847 |
\
|
\
|
6848 |
6848 |
|
|
6849 |
6849 |
Note that CONTACT could be a weak entity, with the identifying relationship being either DISCUSSED_BY or EMPLOYS, but both have disadvantages, since they would disallow a CONTACT to discuss more than one offer, or to be hired by more than one company.
|
Note that CONTACT could be a weak entity, with the identifying relationship being either DISCUSSED_BY or EMPLOYS, but both have disadvantages, since they would disallow a CONTACT to discuss more than one offer, or to be hired by more than one company.
|
|
... |
... |
Solution to [%D %n (%T)](#problem:ERtoRELBike) |
6869 |
6869 |
For the $1:M$ relationships that are not identifying, we can chose between the foreign key and the cross-reference approaches.
|
For the $1:M$ relationships that are not identifying, we can chose between the foreign key and the cross-reference approaches.
|
6870 |
6870 |
If we use the former, we obtain:
|
If we use the former, we obtain:
|
6871 |
6871 |
|
|
6872 |
|
data:image/s3,"s3://crabby-images/1148d/1148d75517a504b06d4a8550ec9fff2cbc57ca20" alt=""
|
|
|
6872 |
|
data:image/s3,"s3://crabby-images/90370/903701f245d30fe19ebbb2aee6fb4fa66f22906e" alt=""
|
6873 |
6873 |
|
|
6874 |
6874 |
We could also have used a combination of both!
|
We could also have used a combination of both!
|
6875 |
6875 |
|
|
|
... |
... |
SHOP(Name (PK), StreetName, Citiy, Zip) |
6902 |
6902 |
LABEL(Name (PK), Phone, LogoName, LogoColor)
|
LABEL(Name (PK), Phone, LogoName, LogoColor)
|
6903 |
6903 |
SELL(Recording (FK, PK to RECORDING.Title), Shop (PK, FK to SHOP.Name), NumberOfCopies)
|
SELL(Recording (FK, PK to RECORDING.Title), Shop (PK, FK to SHOP.Name), NumberOfCopies)
|
6904 |
6904 |
LABELGENRE(Label (PK, FK to LABEL.Name), Genre (PK))
|
LABELGENRE(Label (PK, FK to LABEL.Name), Genre (PK))
|
6905 |
|
](fig/rel_mod/RECORD)\
|
|
|
6905 |
|
](fig/rel_mod/record)\
|
6906 |
6906 |
|
|
6907 |
6907 |
---
|
---
|
6908 |
6908 |
|
|
|
... |
... |
Solution to [%D %n (%T)](#problem:schedule) |
6968 |
6968 |
|
|
6969 |
6969 |
Once normalized to the third normal form, we get:
|
Once normalized to the third normal form, we get:
|
6970 |
6970 |
|
|
6971 |
|
data:image/s3,"s3://crabby-images/e074a/e074af9ee946a42746e3cb5f9c021f797f978445" alt=""{width=90%}
|
|
|
6971 |
|
data:image/s3,"s3://crabby-images/8ce24/8ce24b649e89c54c54a717e20055c8f838f1e096" alt=""{width=90%}
|
6972 |
6972 |
|
|
6973 |
6973 |
|
|
6974 |
6974 |
---
|
---
|
|
... |
... |
Solution to [%D %n (%T)](#problem:carinfo) |
7123 |
7123 |
PERSON(ID (PK), Name, Street, City, Seat (FK to CAR.Vin), Position)
|
PERSON(ID (PK), Name, Street, City, Seat (FK to CAR.Vin), Position)
|
7124 |
7124 |
CAR(Vin (PK), Make, Year, Brand, Driver (FK to PERSON.ID))
|
CAR(Vin (PK), Make, Year, Brand, Driver (FK to PERSON.ID))
|
7125 |
7125 |
CAR INSURANCE(Insured Car (PK, FK to CAR.Vin), Policy Number (PK), Covered Amount, Company Name)
|
CAR INSURANCE(Insured Car (PK, FK to CAR.Vin), Policy Number (PK), Covered Amount, Company Name)
|
7126 |
|
](fig/rel_mod/CAR_INFO)
|
|
|
7126 |
|
](fig/rel_mod/car_info)
|
7127 |
7127 |
\
|
\
|
7128 |
7128 |
|
|
7129 |
7129 |
Note that, during the coversion, we had to make "Insured Car" part of the primary key of CAR INSURANCE.
|
Note that, during the coversion, we had to make "Insured Car" part of the primary key of CAR INSURANCE.
|
|
... |
... |
Solution to [%D %n (%T)](#problem:library_network) |
7137 |
7137 |
|
|
7138 |
7138 |
For the ER diagram, we could get something like:
|
For the ER diagram, we could get something like:
|
7139 |
7139 |
|
|
7140 |
|
data:image/s3,"s3://crabby-images/c28b2/c28b2a3316a702221ed6bf5fa6f23f17f3ef450f" alt=""
|
|
|
7140 |
|
data:image/s3,"s3://crabby-images/197b9/197b9c640a03033dca4ae5fb5942a36a06ad8952" alt=""
|
7141 |
7141 |
|
|
7142 |
7142 |
Note that:
|
Note that:
|
7143 |
7143 |
|
|
|
... |
... |
Solution to [%D %n (%T)](#problem:library_network) |
7157 |
7157 |
BORROWING(Copy (PK, FK to COPY.Code), Patron (PK, FK to PATRON.CardNumber), ReturnDate)
|
BORROWING(Copy (PK, FK to COPY.Code), Patron (PK, FK to PATRON.CardNumber), ReturnDate)
|
7158 |
7158 |
PATRON(CardNumber (PK), Name, Email)
|
PATRON(CardNumber (PK), Name, Email)
|
7159 |
7159 |
HOLD(Copy (PK, FK to COPY.Code), Patron (PK, FK to PATRON.CardNumber), ExpirationDate)
|
HOLD(Copy (PK, FK to COPY.Code), Patron (PK, FK to PATRON.CardNumber), ExpirationDate)
|
7160 |
|
](fig/rel_mod/NETWORK_LIBRARY)
|
|
|
7160 |
|
](fig/rel_mod/network_library)
|
7161 |
7161 |
\
|
\
|
7162 |
7162 |
|
|
7163 |
7163 |
Note that:
|
Note that:
|
|
... |
... |
Solution to [%D %n (%T)](#problem:xmltoercustomer) |
8635 |
8635 |
|
|
8636 |
8636 |
Put together, this gives the following diagram:
|
Put together, this gives the following diagram:
|
8637 |
8637 |
|
|
8638 |
|
data:image/s3,"s3://crabby-images/71726/7172673544c0c531a7cdbe87643ab40a81d77ac3" alt=""
|
|
|
8638 |
|
data:image/s3,"s3://crabby-images/9f06b/9f06be3e4abdb29ddb6a4c7bc5ab3f930335e18b" alt=""
|
8639 |
8639 |
\
|
\
|
8640 |
8640 |
|
|
8641 |
8641 |
We made further assumptions: an order cannot be empty (transcribed by the total constraint on CONTAINS), an order does not exist if it was not passed by a customer (transcribed by the fact that ORDER is a weak entity), which also implies that an order cannot be passed by more than one customer.
|
We made further assumptions: an order cannot be empty (transcribed by the total constraint on CONTAINS), an order does not exist if it was not passed by a customer (transcribed by the fact that ORDER is a weak entity), which also implies that an order cannot be passed by more than one customer.
|
|
... |
... |
Solution to [%D %n (%T)](#problem:xmltoeraward) |
8669 |
8669 |
|
|
8670 |
8670 |
All together, this gives the following diagram:
|
All together, this gives the following diagram:
|
8671 |
8671 |
|
|
8672 |
|
data:image/s3,"s3://crabby-images/ff011/ff0110b3e05964ef69605c34b493dfe5a0d88455" alt=""
|
|
|
8672 |
|
data:image/s3,"s3://crabby-images/bf5b5/bf5b5f9c9286e3988272825ab27a93b238775765" alt=""
|
8673 |
8673 |
\
|
\
|
8674 |
8674 |
|
|
8675 |
8675 |
|
|