Task 1: Gather data to identify business requirement
In this section we describe a sample database application, called COMPANY, which serves to
illustrate the basic ER model concepts and their use in schema design. We list the data
requirements for the database and then create its conceptual schema using the modeling concepts
of the ER model. The COMPANY database keeps track of a company’s employees, departments,
and projects. Suppose that after the requirements collection and analysis phase, the database
designers provide the following description of the mini world—the part of the company that will
be represented in the database.
The company is organized into departments. Each department has a unique name, a unique
number, and a particular employee who manages the department. We keep track of the start date
when that employee began managing the department. A department may have several locations.
A department controls a number of projects, each of which has a unique name, a unique number,
and a single location.
The database will store each employee’s name, Social Security number, address, salary, sex
(gender), and birth date. An employee is assigned to one department, but may work on several
projects, which are not necessarily controlled by the same department. It is required to keep track
of the current number of hours per week that an employee works on each project, as well as the
direct supervisor of each employee (who is another employee).
The database will keep track of the dependents of each employee for insurance purposes,
including each dependent’s first name, sex, birth date, and relationship to the employee.
Solution of Task 1
Based on the requirements, we can identify four initial entity types in the COMPANY database:
DEPARTMENT
PROJECT
EMPLOYEE
DEPENDENT
Attributes of each tables are the following
Employee has Social Security number, address, salary, sex (gender), and birth date. Attributess
Department entity has department name, department location department number and others
attributes.
Project entity has project name, project number, project location and date attributes.
Dependents entity has dependent name, sex, BDate, relationship and social security number
attributes.
Solution of Task 2
By examining the requirements, six relationship types are identified All are binary relationships (
degree 2) and Listed below with their participating entity types:
WORKS_FOR (between EMPLOYEE, DEPARTMENT)
MANAGES (also between EMPLOYEE, DEPARTMENT)
CONTROLS (between DEPARTMENT, PROJECT)
WORKS_ON (between EMPLOYEE, PROJECT)
SUPERVISION (between EMPLOYEE (as subordinate), EMPLOYEE (as supervisor))
DEPENDENTS_OF (between EMPLOYEE, DEPENDENT)=
1. MANAGES, a 1:1 relationship type between EMPLOYEE and DEPARTMENT.
EMPLOYEE participation is partial. DEPARTMENT participation is not clear from the
requirements. We question the users, who say that a department must have a manager at
all times, which implies total participation (Note 12). The attribute StartDate is assigned
to this relationship type.
2. WORKS_FOR, a 1:N relationship type between DEPARTMENT and EMPLOYEE. Both
participations are total.
3. CONTROLS, a 1:N relationship type between DEPARTMENT and PROJECT. The
participation of PROJECT is total, whereas that of DEPARTMENT is determined to be
partial, after consultation with the users.
4. SUPERVISION, a 1:N relationship type between EMPLOYEE (in the supervisor role) and
EMPLOYEE (in the supervisee role). Both participations are determined to be partial,
after the users indicate that not every employee is a supervisor and not every employee
has a supervisor.
5. WORKS_ON, determined to be an M:N relationship type with attribute Hours, after the
users indicate that a project can have several employees working on it. Both
participations are determined to be total.
6. DEPENDENTS_OF, a 1:N relationship type between EMPLOYEE and DEPENDENT,
which is also the identifying relationship for the weak entity type DEPENDENT. The
participation of EMPLOYEE is partial, whereas that of DEPENDENT is total.
Task 3: Draw ER diagram
Name Name Name
Address Name Salary
Sex
BDate
Employee N
SS Works For
N
Start date 1
Number
1 N
Num empl
1 1 1
Location
Department
Supervision Manages
M 1
Name
of Dependents Controls
Works On
of
N N
N
Hours
Dependent Project
Name
Number Location
Name Sex BDate Relationship
Solution for task 4
Mapping ERD model into relational Model
• Use ERD model
• Identify each entities as table
• Mapping of Regular Entity Types
• Mapping of Weak Entity Types
• Mapping of Binary 1:1 Relation Types
• Mapping of Binary 1:N Relationship Types.
• Mapping of Multivalued attributes.
• Identify each attribute with its row and column
• Identify primary key with table
• Convert into relational data model
According to company database we have four entities: that is employee, department, project and
dependent table.
Mapping of Regular Entity Types.
For each regular (strong) entity type E in the ER schema, create a relation R that includes
all the simple attributes of E.
Choose one of the key attributes of E as the primary key for R.
If the chosen key of E is composite, the set of simple attributes that form it will together
form the primary key of R.
Example: We create the relations EMPLOYEE, DEPARTMENT, and PROJECT in the
relational schema corresponding to the regular entities in the ER diagram.
SSN, DNUMBER, and PNUMBER are the primary keys for the relations EMPLOYEE,
DEPARTMENT, and PROJECT
Mapping of Weak Entity Types
For each weak entity type W in the ER schema with owner entity type E, create a
relation R & include all simple attributes (or simple components of composite attributes)
of attributes of R.
Also, include as foreign key attributes of R the primary key attribute(s) of the relation(s)
that correspond to the owner entity type(s).
The primary key of R is the combination of the primary key(s) of the owner(s) and the
partial key of the weak entity type W.
Example: Create the relation DEPENDENT in this step to correspond to the weak entity
type DEPENDENT.
Include the primary key SSN of the EMPLOYEE relation as a foreign key attribute of
DEPENDENT
The primary key of the DEPENDENT relation is the combination
{SSN, DEPENDENT_NAME} because DEPENDENT_NAME is the partial key of
DEPENDENT.
Mapping of Binary 1:1 Relation Types
For each binary 1:1 relationship type R in the ER schema, identify the relations S and T
that correspond to the entity types participating in R.
Foreign Key approach: Choose one of the relations-say S-and include a foreign key in S
the primary key of T. It is better to choose an entity type with total participation in R in
the role of S.
Example: 1:1 relation MANAGES is mapped by choosing the participating entity type
DEPARTMENT to serve in the role of S, because its participation in the MANAGES
relationship type is total.
Mapping of Binary 1: N Relationship Types.
For each regular binary 1: N relationship type R, identify the relation S that represent the
participating entity type at the N-side of the relationship type.
Include as foreign key in S the primary key of the relation T that represents the other
entity type participating in R. 1: N relationship types WORKS_FOR.
CONTROLS, and SUPERVISION
For WORKS_FOR we include the primary key DNUMBER of the DEPARTMENT
relation as foreign key in the EMPLOYEE relation and call it DNO.
Mapping of Binary M: N Relationship Types.
For each regular binary M: N relationship type R, create a new relation S to represent R.
Include as foreign key attributes in S the primary keys of the relations that represent the
participating entity types; their combination will form the primary key of S.
Also include any simple attributes of the M:N relationship type (or simple components
of composite attributes) as attributes of S.
The M:N relationship type WORKS_ON from the
ER diagram is mapped by creating a relation WORKS_ON in the relational database
schema.
The primary keys of the PROJECT and EMPLOYEE relations are included as foreign
keys in WORKS_ON and renamed PNO and SSN, respectively.
Attribute HOURS in WORKS_ON represents the HOURS attribute of the relation type.
The primary key of the WORKS_ON relation is them combination of the foreign key
attributes {SSN, PNO}.
Mapping of Multivalued attributes.
For each multivalued attribute A, create a new relation R.
This relation R will include an attribute corresponding to A, plus the primary key
attribute K-as a foreign key in R-of the relation that represents the entity type of
relationship type that has A as an attribute.
The primary key of R is the combination of A and K. If the multivalued attribute is
composite, we include its simple components.
The relation DEPT_LOCATIONS is created.
The attribute DLOCATION represents the multivalued attribute
LOCATIONS of DEPARTMENT, while DNUMBER-as foreign key represents the
primary key of the DEPARTMENT relation.
The primary key of R is the combination of {DNUMBER, DLOCATION}.
Mapping of N-ary Relationship Types.
For each n-ary relationship type R, where n>2, create a new relationship S to represent
R.
Include as foreign key attributes in S the primary keys of the relations that represent the
participating entity types.
Also include any simple attributes of the n-ary relationship type (or simple components
of composite attributes) as attributes of S.
Example: The relationship type SUPPLY .This can be mapped to the relation SUPPLY
shown in the relational schema, whose primary key is the combination of the three
foreign keys {SNAME, PARTNO, PROJNAME}