210 likes | 317 Views
2mis6010-L Databases and Spreadsheets. Lecturer Nishant Pithia. Week 2: Database Design. Lecture : a gentle introduction to database design, using last week practical exercises as an example Practical Session : Database Design with E-R Diagram. Database Design.
E N D
2mis6010-L Databases and Spreadsheets Lecturer Nishant Pithia
Week 2: Database Design • Lecture: a gentle introduction to database design, using last week practical exercises as an example • Practical Session: Database Design with E-R Diagram
Database Design • DB Design is the process of creating a design for a database that will • support the enterprise’s operations and objectives • and meet the enterprise’s information needs. • Standard Approaches for DB Design: • E-R Diagram • Normalization
Database Design – E-R Diagram (ERD) • Entity-Relationship (ER) Modeling is a conceptual modeling technique to identify the entities and the relationship between the entities for relational database design. • Elements of ERD: • Entity: a group of real life objects (such as people, products, and so on) with the same properties. In Ms Access, an entity is used to represent a table. 2. Attribute: a property of an entity. In Ms Access, attributes are referred to those fields/columns in the tables.
Elements of ERD –Primary Key and Entity Integrity Elements of ERD: • Primary Key: the attribute used to uniquely identify each occurrence of an entity. In Ms Access, PK is the key attribute as an ID to uniquely identify data for each row/entry. For every table, there must be PK(s) to identify each row of data. Entity Integrity: An Integrity Constraint of DB setting following rules • The Existence of PK value: PK can not be null value (i.e. must contain some value). A null values is an unknown value. • The Uniqueness of PK Value: the value of PK for each row must be different. Otherwise, you will violate the entity integrity of the database. For standard database design, these essential elements can be presented in E-R diagram
Entity and Attribute for Last week Exercise For example, • Customer as an entity having attributes, such as No, name, address; Customer No is the PK for Customer table. • Product as an entity having attributes, such as No, name; Product No is the PK for Customer table. • Order as an entity having attributes, such as No, name; Product No is the PK for Customer table. Description name No No Name Name No Address Customer Order Product
Example of Entity Integrity and PK For each entity with attributes, you will have following proposed table view in mind (not the real database).
ERD Element - Relationship For relational database, We use “relationship” as an element to link different entities together instead of isolating them from one another. • Relationship: a set of meaningful association among entities. • Different types of association between entities • One-to-one • One-to-many (or Many-to-one) • Many-to-many
Types of Relationship with examples • One-to-one: the head of a Department manages the department. Head manages Department Each Head can only manage one department, each department can be only managed by one head.
Types of Relationship with examples • One to Many (or Many-to-one) Department Course Has Is_Run_In IT Physics Arts Msc IT Bsc IT Bsc Physics BA Arts MA Arts Each department has one or more courses; each course can be only run in a particular department.
Types of Relationship with examples • Many-to-Many Department Course Has Is_Run_In IT Physics Arts Msc IT Bsc Physics and IT BA Arts With IT BA Arts Each department has one or more courses; each course can be run in more than one department.
Some Tips for Database Design Step 1:Identify the entities with attributes and the Relationships among entities • Make assumptions, by clearly understanding the scenario/background information for your database design. (Different assumptions will bring your totally different DB design!!!) • Map entities with attributes and Find the “direct relationship” between different entities. (must have very clear logic) • Clearly identify the types of relationship Step 2: Use some rules to check your design Step 3: Realize the Relationships in table view • Find and create Foreign Key (thematching field) between the entities (tables) as the link to realize the relationship Step 4: Normalize the Tables.
Step 1 for Last Week Exercises Entity View with Attributes Customer Product Order • Think About: Any Assumption for this example? What are the relationships among entities? Where are the direct relationships? Proposed Table View with PK Under Entity Integrity
Step 1 for Last Week Exercises Under Assumption 1 One Customer has one or more orders; each order can only belong to a particular customer (different customers’ names can not appear in the same order) An Order can have more than one product; each product can be only belong to a particular customer’s order (bespoken or personalized products. e.g. Rolls Royce; designer branded fashion for celebrities) Assumption 1 D021 B001 M746 B111 A222 C122 U120 U129 Anderson Cooper King O214 O315 O266 O478 O122 Conceptual View ER View Order Customer Product
Step 1 for Last Week Exercises Under Assumption 2 One Customer has one or more orders; each order can only belong to a particular customer (different customers’ names can not appear in the same order) One Order can contain more than one product; each product can appear in different orders. (e.g. consumer products. e.g. clothes in shopping centre; books, etc… ) Assumption 2 D021 B001 B111 C122 U120 U129 Anderson Cooper King O214 O315 O266 O478 O122 Conceptual View ER View Customer Order Product
Step 2: Some General Rules for Good DB Design For multiple 1:M (or M:1) relationships • Try to avoid such fan shape connection for database design in ER View Customer Order Product Problem: What are the products in the order?? • Fan shape “trap” will exist when the direct relationship is incorrectly identified In our example (Slide 14 & 15), under different assumptions, both DB Design in ER View do not have fan shape.
Step 3 –Finding and CreateForeign KeyforRelationship in Table View • Foreign Key (FK) isan attribute/a field of one table and a primary key of another table. It is the matching field between interrelated tables. • The use of FK introduces another new integrity constraint - Referential Integrity (or FK constraint). • It simply sets a rule that: if a FK exists in a table, the value of the FK must match the value of the primary key of some row in another table.
Example of FK and RI • Which is the PK to be created as a FK in another table for relationship? Course_Code or Dept_ID? • Dept_ID (the PK of department) in Course table as the FK to link • and represent the relationship between them.
Step 3 for Last Week Exercise- Under Assumption 1 Violate Entity Integrity (No Duplication for PK value)