Entities Entities are the people, places, things, or events that are of interest for a system that we are planning to build. Some samples of entities are:

Slides:



Advertisements
Similar presentations
1 Database Theoretic Basis Entity Relationship (E-R) Modeling Database Theoretic Basis Entity Relationship (E-R) Modeling.
Advertisements

Ch5: ER Diagrams - Part 1 Much of the material presented in these slides was developed by Dr. Ramon Lawrence at the University of Iowa.
Chapter 4 Entity Relationship (E-R) Modeling
Entity Relationship (ER) Modeling
1 Entities Entities are the people, places, things, or events that are of interest for a system that we are planning to build. Some samples of entities.
Normalization Normalization We discuss four normal forms: first, second, third, and Boyce-Codd normal forms 1NF, 2NF, 3NF, and BCNF Normalization.
1 Relationships Relationships will have justification in business rules, in the way the enterprise manages its business. The following figure illustrates.
Chapter 3 Data Modeling Using the Entity- Relationship (ER) Model Dr. Bernard Chen Ph.D. University of Central Arkansas.
Data Modeling Using the Entity-Relationship Model
Data Modeling Using the Entity-Relationship Model
DeSiamorewww.desiamore.com/ifm1 Database Management Systems (DBMS)  B. Computer Science and BSc IT Year 1.
CONCEPTS OF E-R MODEL. CONTENTS Entity Attributes Data Value Entity Types Types of Entity Types Relationships Relationship Constraints.
Entities and Attributes
Database. Basic Definitions Database: A collection of related data. Database Management System (DBMS): A software package/ system to facilitate the creation.
Module Title? Data Base Design 30/6/2007 Entity Relationship Diagrams (ERDs)
1 ER Modeling BUAD/American University Entity Relationship (ER) Modeling.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 7 Data Modeling Using the Entity- Relationship (ER) Model.
Chapter 3 Data Modeling Using the Entity- Relationship (ER) Model Dr. Bernard Chen Ph.D. University of Central Arkansas Fall 2008.
Initial Design of Entity Types for the COMPANY Database Schema Based on the requirements, we can identify four initial entity types in the COMPANY database:
DeSiamorePowered by DeSiaMore1 Database Management Systems (DBMS)  B. Computer Science and BSc IT Year 1.
3 & 4 1 Chapters 3 and 4 Drawing ERDs October 16, 2006 Week 3.
Msigwaemhttp//:msigwaem.ueuo.com/1 Database Management Systems (DBMS)  B. Computer Science and BSc IT Year 1.
1 A Demo of Logical Database Design. 2 Aim of the demo To develop an understanding of the logical view of data and the importance of the relational model.
Data modeling using the entity-relationship model Chapter 3 Objectives How entities, tuples, attributes and relationships among entities are represented.
Database Beginnings CIS 121 – Computer Concepts II Instructor: Ron Christensen.
advanced data modeling
Data Modeling Using the Entity-Relationship (ER) Data Model.
Database Design Theory CS405G: Introduction to Database Systems Jinze Liu 3/15/20161.
Entity-Relationship Data Model
Entity Relationship (E-R) Model
Data Modeling Using the Entity- Relationship (ER) Model
Comp 1100 Entity-Relationship (ER) Model
Data Modeling Using the Entity- Relationship (ER) Model
Let try to identify the conectivity of these entity relationship
Entity-Relationship Model
CS4222 Principles of Database System
Data Modeling Using the Entity- Relationship (ER) Model
Database Management Systems
Entity- Relationship (ER) Model
Enhanced Entity-Relationship and Object Modeling Objectives
ER model Ashima Wadhwa.
Entity Relationship Model
Entity Relationship (E-R) Modeling
Entity Relationship (E-R) Modeling
Entity-Relationship Model
Tables and Their Characteristics
Entity-Relationship Modeling
ER MODEL Lecture 3.
بسم الله الرحمن الرحيم.
Entity Relationship Diagram
Normalization There is a sequence to normal forms:
Entity Relationship Diagrams
Foreign key (FK) is defined as follows:
Entity-Relationship Model
Database Systems: Design, Implementation, and Management Tenth Edition
Normalization Normalization
MIS2502: Data Analytics Relational Data Modeling
Entity Relationship Model
Database Modeling using Entity Relationship Model (E-R Model)
Mapping an ERD to a Relational Database
Relationships Relationships will have justification in business rules, in the way the enterprise manages its business. The following figure illustrates.
Database Design Theory CS405G: Introduction to Database Systems
MIS2502: Data Analytics Relational Data Modeling 2
Entity Relation Model Tingting Zhang.
ER MODELING Instructor: SAMIA ARSHAD
Entity-Relationship Data Model
Entity Relationship (ER) Modeling
Chapter # 4 Entity Relationship (ER) Modeling.
Mapping an ERD to a Relational Database
Database Normalization
Presentation transcript:

Entities Entities are the people, places, things, or events that are of interest for a system that we are planning to build. Some samples of entities are: People: student, customer, employee, etc. Places: resort, city, country, etc. Things: restaurant, product, invoice, movie, painting, book, building, contract, etc. Events: registration, election, presentation, earthquake, hurricane, etc.

Entities Exercise 1: Consider your educational institution. Your educational institution needs to keep track of its students. How many student entities does it have? What attributes describe these entities? Exercise 2: Consider your place of work. The Human Resources department in your company needs to manage information about its employees. How many employee entities does it have? What attributes describe these entities?

Entity sets Entity sets are collections of related entities Entities are related by their classification: 1. student entities are related by the fact that they are all students 2. invoice entities are related by the fact that they are all invoices 3. car entities are related by the fact that they are all cars 4. a department entity set does not contain invoice entities 5. a product entity set does not contain employee entities

Entity sets are named after the entities that belong to the set. It is a common convention that entity set names are singular and that, at least, the first letter is capitalized. For example, An entity set named Student contains student entities. An entity set named Invoice contains invoice entities. An entity set named InvoiceLine contains invoice line entities. 4. An entity set named Product contains product entities.

Occasionally we find it useful to use a set diagram to represent an entity set and its entities. John Amelia Lee April This student entity set has four entities in it: John, Amelia, Lee, and April

Exercise 3: Consider your educational institution or place of work. What are some of the entity sets that would be useful? Based on your knowledge of the organization, draw some entity sets (similar to the figure on page 5) that illustrate some of the entities you know of.   In practice, you may not hear the term entity set used very often. When an analyst or modeler makes reference to an entity set Student, you are more likely to hear them say something like “We need a Student entity” instead of “We need a Student entity set”.

Exercise 4: Consider the previous exercise, but now We use a rectangular symbol to represent an entity set in the Entity Relationship Diagram. Student Department Course Exercise 4: Consider the previous exercise, but now draw an ERD depicting the entity sets as done in above figure.

Weak Entities Sometimes we know certain entities only exist in relationship to others Consider an invoice and the lines on that invoice on each line there are details pertaining to the quantity and price for a product An invoice line is something that will exist only if the corresponding invoice exists We say in a case like this, that an Invoice Line is a weak entity; it is existence-dependent on another entity. For a weak entity, the primary key cannot be recognized.

Exercise 5: Consider a requirement having to do with Invoice Invoice Line An Invoice Line is existence-dependent on an Invoice, and so it is shown with a double-lined rectangle. Exercise 5: Consider a requirement having to do with benefits that may be given to employees of a company. Suppose it is necessary to know something about each employee’s dependents. Illustrate employees and dependents as separate entity sets. Can one of these entity sets be considered a weak entity set?

Attributes Attributes are the characteristics that describe entities A Student entity may be described by attributes including: - student number - name - address - date of birth - degree major

An Invoice entity may be described by attributes including: - invoice number - invoice date - invoice total

We illustrate attributes using ovals. number date Invoice total An entity set, Invoice, with three attributes.

A common convention for naming attributes is to use singular nouns. A naming convention may require one of: All characters are in upper case. All characters are in lower case. Only the first character is in upper case. Each part of a multipart name has the first character Capitalized.  

A typical convention is for attribute names to have prefix that indicates the entity the attribute describes. Subsequent characters are sufficiently descriptive to identify the attribute. Some examples of attribute names: Lname = last name empLname = employee last name stuGpa = student grade point average ProdCode = product code InvNum = invoice number

proNum proPrice specifies proDesc Product InvDate lists Invoice InvLine invAmount invNum invLineNum invLineQty invDate A simple ERD illustrating entities and attributes

Attribute Classification Atomic Attributes Composite Attributes Single-valued Attributes Multi-valued Attributes Key Attributes Partial Keys Surrogate Key Non-key Attributes Derived Attributes

A simple, or atomic, attribute is one that cannot be Atomic Attributes A simple, or atomic, attribute is one that cannot be decomposed into meaningful components   Example an attribute for product price, prodPrice, cannot be decomposed, because you cannot subdivide prodPrice into a finer set of meaningful attributes. the value of the attribute prodPrice could be $21.03. Of course, one could decompose prodPrice into two attributes the dollar component (21), and the cents component (03) but our assumption here is that such a decomposition is not meaningful to the intended application or system that will make use of it.

Exercise 6: Make a list of attributes that would be required for a) a student entity set, b) for an employee. Consider each of your attributes, and verify that each is atomic. Create an ERD that illustrates the entity set and its attributes.

Composite Attributes A composite attribute is an attribute that is shown as comprising two or more simpler attributes; we show a composite attribute in the figure below. empLname empFname Employee empName empName shown as a composite attribute

Exercise 7: Many entities will need an address attribute. For example, a student has an address, an employee has an address. Show, in an ERD, how the address attribute can be shown as a composite attribute.

Single-valued Attributes An attribute is single-valued if, for any instance of the pertinent entity set, there is only one value at a given time for the attribute. empGender Employee Exercise 8: A college or university will keep track of several addresses for a student, but each of these can be named differently: for example, consider that a student has a mailing address and a home address. Create an ER for a student entity set with two composite single-valued attributes for student addresses.

Multi-valued Attributes Consider an attribute to track each employee’s university degrees - empDegree.   Since an employee could have none, one, or several degrees, we say empDegree is multi-valued. sample data for three employees. empNum empPhone empDegree 123 233-9876   333 233-1231 BA, BSc, PhD 679 BSc, MSc One of these employees has no degrees, another has 3 degrees, and the last one has 2 degrees.

empDegree is shown as a multi-valued attribute empPhone empDegree empNum Employee The presence of a multi-valued attribute indicates an area that may require more analysis.

Exercise 9: Consider the employee entity set. Suppose the company needs to track the names of the dependents for each employee. Show the empDependentName as a multi-valued attribute. Modify your ERD to show empDependentName as a composite attribute comprising first and last names and middle initials.   Exercise 10: Create a new ERD that avoids the multi-valued attribute in the figure on page 22. Hint: Consider including another entity set - one for only keeping track of employee information and one for keeping track of each employee's degrees.

Key Attributes A key is an attribute, or combination of attributes, where the attribute value identifies an individual entity   Suppose an educational institution assigns students individual student numbers in such a way that each student’s number is different from that assigned to any other student Student numbers are unique, each student has a different number.

In an ERD, keys are shown underlined: Student stuNum For every entity set, we want to specify which attribute is a key attribute. In this case, Student is shown to have a key named stuNum.

Exercise 11: Suppose a company that sells products has identified that the product entity set has the following attributes: prodNum, prodDesc, prodPrice. Suppose all three products are single-valued and that prodNum is a key attribute - each product has a different product number. Illustrate this knowledge regarding products in an ERD.   Exercise 12: Suppose a college comprises a number of departments. Suppose also that the college assigns each department a unique number and a unique name. That is, no two departments will have the same number or name. Suppose the college also tracks the name of each department chair and general office number. Illustrate the department entity set and attributes in an ERD.

Partial Keys Sometimes we have attributes that distinguish entities of an entity set from other entities in the same set, but only relative to some other related entity.   This situation arises naturally when we model things like invoices and invoice lines. - if invoice lines are assigned line numbers (1, 2, 3, etc.), these line numbers distinguish lines on one invoice from one another. - for any given line number value, there could be many invoice lines (from separate invoices). Invoice line number is a partial key, or discriminator, for invoice lines.

Some attributes may serve the purpose of discriminating invNum Some attributes may serve the purpose of discriminating between instances of entities related to some other entity Invoice invLineNum InvoiceLine Exercise 13: Consider an educational institution that has departments and where each department offers courses. Typically, departments are assigned unique numbers and so DeptNum is a key for the department entity set. However, suppose course numbers are unique within a department, but not across departments. So, History may have a course numbered 215, and English could have a course numbered 215 as well. In order to identify a particular course we need to know the department and we need to know the course number. Illustrate an ER model including department and course entity sets. Include attributes for the department name, course title, and course description.

When a key specified for an entity is meaningless to the Surrogate Key When a key specified for an entity is meaningless to the entity (it doesn’t describe any characteristic of an entity), and when it has a simple numeric value, the key is referred to as a surrogate key.   A key that is not a surrogate key is often referred to as a natural key. - One way of determining if your key attribute is a surrogate key or not, is to consider whether the attribute's value is useful to an end-user. If it is not meaningful to the end-users and if is a simple integer, then it’s called a surrogate key. Exercise 14: Would you consider invoice line number to be a surrogate key?

Non-key attributes are attributes that are a key   most attributes are simply descriptive, and fall into this category. Consider attributes for first name, last name, birth date; usually these attributes are non-key attributes. Consider a name attribute People may join your organization and arrive with a name; we expect many people in a large organization to have the same first name, same last name, and even the same combination of first and last name. Names cannot usually be used as a key. Names that are chosen for entities such as departments in an organisation could be keys because of the way the company would choose department names - they wouldn't give two different departments the same name.

Determining key attributes is an important exercise, and one that requires careful consideration. Most attributes are non-key attributes.   Exercise 15: Consider an employee entity set and decide which attributes are key attributes and which ones are non-key attributes. Illustrate with an ERD.

Derived Attributes If an attribute’s value can be derived from the values of other attributes, then the attribute is derivable, and is said to be a derived attribute   Example if we have two attributes for an employee, birth date and current age, then age is derivable by subtracting the birth date from the current date. birthdate Student age The age of the employee is a derived attribute.

Properties of Attributes Must each attribute have a value? Sometimes you won’t know the value of an attribute until a certain event occurs. Example An Education model has an Enrollment entity set with attributes for the grade awarded to a student in a course, enrGrade, and for the date the student registered, enrDateRegistered. enrGrade Enrollment enrDateRegistered

Sample data showing a Null for student 1, course 765 in department 5. StuNum DeptNum CourseNum EnrGrade EnrDateRegistered 1 5 661 A Jan 1, 2018 765   Sept 1, 2018 2 6 B

A domain is a set of values. Examples Domains A domain is a set of values.   Examples A college that assigns each student a student number could decide the domain of student numbers is the set of positive 7-digit integers. The total for an invoice, InvTotal, and the price of a product, prodPrice, are both associated with the domain of non-negative currency values. The quantity on an invoice line, InvLineQty, is associated with the domain of non-negative integers. Knowing the underlying domains in your model is important. They help to complete your analysis, they are indispensable for coding specifications, and they are useful for defining meaningful error messages

About Foreign Key A foreign key is an attribute associated with an entity, which is used to establish a relationship between two entity sets. (Foreign key is not a concept in ERD, but in the relational model.)   Constraint on foreign keys: The domain of a foreign key must be the same as that of the key of another entity. Any value for a foreign key (attribute) must appears in the value set for the key of the related entity or a null value. 

Dept- No. … Essn 1 661 2 765 3 768 4 ssn … salary 661 765 768 567 Example manage Department Employee Dept- No. … Essn 1 661 2 765 3 768 4 ssn … salary 661 765 768 567 Referential integrity