Escolar Documentos
Profissional Documentos
Cultura Documentos
2004 John Mylopoulos The Entity-Relationship Model -- 1 2004 John Mylopoulos The Entity-Relationship Model -- 2
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Entities
Represent classes of objects (facts, things, people,...) that
have properties in common and an autonomous existence,
e.g., City, Department, Employee, Purchase and Sale.
The Constructs of An instance of an entity is an object in the class represented
the E-R Model by the entity, e.g., Stockholm, Helsinki, are examples of
instances of the entity City; Peterson and Johanson are
examples of instances of the Employee entity.
[The E-R model is very different from the relational model in
which it is not possible to represent an object without
knowing its properties, e.g., an employee is represented by
AND/XOR a tuple containing the name, surname, age, and other
attributes.]
2004 John Mylopoulos The Entity-Relationship Model -- 3 2004 John Mylopoulos The Entity-Relationship Model -- 4
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 5 2004 John Mylopoulos The Entity-Relationship Model -- 6
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Exam
Note: A student can’t take more than one exam for a
particular course!
2004 John Mylopoulos The Entity-Relationship Model -- 7 2004 John Mylopoulos The Entity-Relationship Model -- 8
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 11 2004 John Mylopoulos The Entity-Relationship Model -- 12
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Shipment
Shipment Part
Part
Attributes
FilledBy Contains
Describe elementary properties of entities or relationships.
AND Order
Order XOR
For example, Surname, Salary and Age are attributes of
Generates
Generates Requests
Requests
Invoice
Invoice Service
Service
Employee, while Date and Mark are attributes of
relationship Exam between Student and Course.
FilledBy Contains
Contains Part
An attribute associates with each instance of an entity (or
Shipment
Shipment FilledBy Order Part
Order relationship) one or more values belonging to its domain.
Attributes may be single-valued, or multi-valued.
Requests
Requests
Invoice
Invoice Generates
Generates Service
Service
2004 John Mylopoulos The Entity-Relationship Model -- 13 2004 John Mylopoulos The Entity-Relationship Model -- 14
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 15 2004 John Mylopoulos The Entity-Relationship Model -- 16
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 17 2004 John Mylopoulos The Entity-Relationship Model -- 18
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 19 2004 John Mylopoulos The Entity-Relationship Model -- 20
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 21 2004 John Mylopoulos The Entity-Relationship Model -- 22
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 23 2004 John Mylopoulos The Entity-Relationship Model -- 24
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 25 2004 John Mylopoulos The Entity-Relationship Model -- 26
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 27 2004 John Mylopoulos The Entity-Relationship Model -- 28
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 29 2004 John Mylopoulos The Entity-Relationship Model -- 30
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
If we use courseinstructor,room
courseinstructor room as identifier for name
Meeting we are stating that there can only be one
Meeting, title
Course dept
meeting for a given instructor+room combination, so an
year
instructor must have all her meetings in different rooms!
sem
Finally, if the attribute courseinstructor by itself forms
an identifier for Meeting,
Meeting then the diagram we have built Suppose we want information on course offerings over the
is stating that each instructor participates in at most one years. What does each of the following identifiers say about the
meeting, again this is unreasonable. application?
name;
name, sem, year;
sem, year;
name, dept;
dept, year.
2004 John Mylopoulos The Entity-Relationship Model -- 31 2004 John Mylopoulos The Entity-Relationship Model -- 32
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Generalizations
Properties of Generalization
Represent logical links between an entity E, known as
parent entity, and one or more entities E1,...,En called Every instance of a child is also an instance of the parent.
child entities, of which E is more general. Every property of the parent entity (attribute, identifier,
We then say that E is a generalization of E1,...,En and relationship or other generalization) is also a property of a
that the entities E1,...,En are specializations of E. child entity. This property of generalizations is known as
inheritance.
2004 John Mylopoulos The Entity-Relationship Model -- 33 2004 John Mylopoulos The Entity-Relationship Model -- 34
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 35 2004 John Mylopoulos The Entity-Relationship Model -- 36
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Example
The E-R Model, as an E-R Diagram
We wish to create a database for a company that runs training courses. For this,
we must store data about the trainees and the instructors. For each course
participant (about 5,000), identified b y a code, we want to store her social
securit y number, surname, age, sex, place of birth, emplo yer’s name, address
and telephone number, previous emplo yers (and periods emplo yed), the
courses attended (there are about 200 courses) and the final assessment for
each course. We need also to represent the seminars that each participant is
attending at present and, for each day, the places and times the classes are
held.
Each course has a code and a title and any course can be given any number of
times. Each time a particular course is given, we will call it an ‘edition’ of the
course. For each edition, we represent the start date, the end date, and the
number of participants. If a trainee is self-emplo yed, we need to know her area
of expertise, and, if appropriate, her title. For somebod y who works for a
company, we store the le vel and position held. For each instructor (about 300),
we will show the surname, age, place of birth, the edition of the course taught,
those taught in the past and the courses that the tutor is qualified to teach. All
the instructors’ telephone numbers are also stored. An instructor can be
permanently emplo yed by the training company or freelance.
2004 John Mylopoulos The Entity-Relationship Model -- 37 2004 John Mylopoulos The Entity-Relationship Model -- 38
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 41 2004 John Mylopoulos The Entity-Relationship Model -- 42
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 43 2004 John Mylopoulos The Entity-Relationship Model -- 44
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 47 2004 John Mylopoulos The Entity-Relationship Model -- 48
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
from Duration to
2004 John Mylopoulos The Entity-Relationship Model -- 49 2004 John Mylopoulos The Entity-Relationship Model -- 50
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 51 2004 John Mylopoulos The Entity-Relationship Model -- 52
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 53 2004 John Mylopoulos The Entity-Relationship Model -- 54
Information Systems Analysis and Design csc340 Information Systems Analysis and Design csc340
2004 John Mylopoulos The Entity-Relationship Model -- 55 2004 John Mylopoulos The Entity-Relationship Model -- 56
ER vs Class Diagrams
ER diagrams allow N-ary relationships, N≥2; Class
diagrams only allow binary relationships.
ER diagrams allow multi-valued attributes, class diagrams
do not.
ER diagrams allow the specification of identifiers (an often-
encountered type of constraint), class diagrams do not.
Class diagrams allow dynamic classification, but ER
diagrams do not.
Class diagrams can have associated methods, constraints
and pre/post-conditions.