Six Blind Men and the Elephant
Basic ERD Symbology EntityRelationship AttributeMultivalued Attribute Associative Entity
Typical Business Relationships PRODUCTS CUSTOMERS are purchased by SUPPLIERS PRODUCTS supply ORDERS PRODUCTS contain ORDERS CUSTOMERS are placed by EMPLOYEES OFFICES are assigned to PRODUCTS STORES are sold in
Relationship Complexities (a) (b) (c) EMPLOYEE OFFICE EMPLOYEE DEPARTMENT STUDENT COURSE Each EMPLOYEE must be assigned to one and only one OFFICE. Each OFFICE may be assigned to one and only one EMPLOYEE. Each EMPLOYEE must be assigned to one and only one DEPARTMENT. Each DEPARTMENT may be in charge of zero or more EMPLOYEEs. Each STUDENT may be registered for zero, one, or many COURSEs. Each COURSE may be taken by zero, one, or many STUDENTs. assigned to in charge of registered for taken by
Unary Relationship PERSON COURSE EMPLOYEE married to is a prerequisite for has as a prerequisite managed by manage Each PERSON may be married to one and only one PERSON. Each COURSE may have zero, one, or many prerequisite COURSEs. Each COURSE may be a prerequisite for zero, one, or many COURSEs. Each EMPLOYEE must be managed by one and only one EMPLOYEE. Each EMPLOYEE may manage zero, one, or many EMPLOYEEs.
Binary Relationship EMPLOYEE STUDENT COURSE assigned to Each EMPLOYEE must be assigned to one and only one OFFICE. Each OFFICE may be assigned to one and only one EMPLOYEE. Each STUDENT may be registered for zero, one, or many COURSEs. Each COURSE may be taken by for zero, one, or many STUDENTs. Each CUSTOMER may place zero, one, or many ORDERs. Each ORDER must be placed by one and only one CUSTOMER. OFFICE CUSTOMER ORDER registered for taken by place placed by
Ternary Relationship STUDENT MAJOR ADVISOR Each STUDENT must have declared one or more MAJORs and be assigned to one or more ADVISORs. Each ADVISOR must be assigned to one or more STUDENTs and be responsible for one or more MAJORS. Each MAJOR must be declared by one or more STUDENTs and be assigned to one or more ADVISORs.
Associative Entity PASSENGER SCHEDULED FLIGHTS PASSENGER SCHEDULED FLIGHTS RESERVATION make reservation reserved by (a) (b)
Reading Relationships Each… entity1 relationship entity2 Each… CUSTOMER may be placing one or more ORDERS. ORDER must be placed by one and only one CUSTOMER must be or may be one or more or one and only one { }
Characteristics of a Good Data Model CharacteristicExplanation Pictorial A good data model should be an accurate graphical depiction of the entities and their relationships Rigorous and Specific A good data model should be specific with regard to the identification of all entities and their relationships and rigorous in the identification and specification of the attributes associated with each entity. Top-down Decomposable A good data model should be decomposable in the sense that the level of detail for each entity and its associated attributes can be investigated at various levels of detail or aggregation. Provide Focus A good data model should be focused on the data associated with a single system and contained within a single system boundary. Minimally Redundant A good data model will display minimal redundancy with regard to repeated entity types, data redundancy, and many-to-many relationships. Transparent The actual data and the physical structure of the database should be discernable from looking at the graphical data model. Easily Navigated A good data model should be laid out in an organized fashion to allow for the relationships among the entities to be easily followed. Predicts the Final System A good data model should be an accurate prediction of the physical implementation of the system.
First Normal Form ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE ORDERED PRODUCT (repeats 1 – n times) PRODUCT ID QUANTITY DESCRIPTION UNIT PRICE EXTENDED PRICE ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY DESCRIPTION UNIT PRICE EXTENDED PRICE (a)(b)
Second Normal Form ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY DESCRIPTION UNIT PRICE EXTENDED PRICE (a)(b) ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY UNIT PRICE EXTENDED PRICE PRODUCT PRODUCT ID DESCRIPTION
Third Normal Form (a)(b) ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY UNIT PRICE EXTENDED PRICE PRODUCT PRODUCT ID DESCRIPTION ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY UNIT PRICE PRODUCT PRODUCT ID DESCRIPTION CUSTOMER CUSTOMER NUMBER CUSTOMER NAME CUSTOMER STREET CUSTOMER CITY CUSTOMER STATE CUSTOMER ZIPCODE CUSTOMER PHONE
Denormalization (a)(b) ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY UNIT PRICE ORDER ORDER NUMBER ORDER DATE CUSTOMER NUMBER ORDER SUBTOTAL SALES TAX SHIPPING ORDER TOTAL ORDERED PRODUCT PRODUCT ID + ORDER NUMBER QUANTITY UNIT PRICE MTD SALES MONTH ID MONTHLY SALES
Fully Normalized ERD ORDER PRODUCT CUSTOMER ORDERED PRODUCT Customer Name Customer Name Customer Street Customer Street Customer City Customer City Customer State Customer State Customer Zipcode Customer Zipcode Customer Number Customer Number Customer Phone Customer Phone Order Date Order Number Customer Number Customer Number Sales Tax Order Subtotal Shipping Order Total Product ID + Order Number Quantity Unit Price Product ID Description
Selecting a Primary Key 99XXX99XX Criteria for SelectionExplanation Stability Choose a candidate key that will not likely change its value over time. EXAMPLE:UNSTABLESTABLE NAME+ADDRESS EMPLOYEE_ID Non-Null Choose a candidate key that is always guaranteed to have a non-null value. EXAMPLE:POSSIBLE NULLNON-NULL PHONE_NO SSN Non-Informational Do not create intelligent keys that attempt to convey information via their structure. EXAMPLE:INFORMATIONALNON-INFORMATIONAL Location Color Shelf Class Code Code Code Code Simplicity Wherever feasible, consider using a single attribute primary key instead of a multi-attribute primary key. EXAMPLE:SINGLE ATTRIBUTEMULTI-ATTRIBUTE ITEM_NO+COLOR ITEM_CODE
Identifying Entities and Relationships Question CategoryDescription Determine System Entities Find out what types of people, business units, things, places, events, materials, or other organizations are associated with, or interact with, the system and about which data must be maintained. Identify Entity Attributes Identify the characteristics by which each entity is associated or identified with. Determine Entity Keys Identify the most appropriate characteristic for each entity that uniquely distinguishes an instance of that entity from all other instances of the same entity. Determine Relationships and Degrees Identify the various events, transactions, or other business activities that infer an association between entities. Determine Cardinalities and Optionalities Identify the circumstances under which each of the relationships can occur. This requires an investigation into the various business rules under which the organization operates and the constraints imposed on the events which occur within the business environment.
Three Normal Forms Normal FormDescription First Normal Form (1NF) A relation is in 1NF if it contains no repeating data elements. Second Normal Form (2NF) A relation is in 2NF if it is in 1NF and contains no partial functional dependencies. Third Normal Form (3NF) A relation is in 3NF if it is in 2NF and contains no transitive dependencies.