Logical Database Design

Download as ppt, pdf, or txt
Download as ppt, pdf, or txt
You are on page 1of 27

LOGICAL DATABASE

DESIGN METHODOLOGIES

DESIGN
The process of constructing a model of the data used in
an enterprise based on a specific data model, but
independent of a particular DBMS and other physical
considerations.
The logical database design phase maps the conceptual
model on to a logical model.

Which is influenced by the data model for the target


database.

The logical data model is a source of information for the


physical design phase.
Step 2 Build and Validate Logical Data
Model

Objective:

To translate the conceptual data model into a logical data


model and then to validate this model to check that it is
structurally correct and able to support the required
transactions.
Step 2 Build and Validate Logical Data
Model-II
Step 2.1 Derive the relations for logical data model
Step 2.2 Validate the relations using normalization
Step 2.3 Validate the relations against the user
transactions
Step 2.4 Check the integrity constraints
Step 2.5 Review the logical data model with user
Step 2.6 Merge the logical data models into global
model (Optional Step)
Step 2.7 Check for future growth
Step 2.1 Derive the relations for logical data
model
Objective: To create relations for the logical data
model to represent the entities, relationships, and
attributes that have been identified.
Using DBDL:
 First specify name of the relation
 List of relations simple attributes enclosed in
brackets.
 Identify the primary key and any alternate and/or
foreign key of the relation
 Any derived attributes are also listed together
with how each one is calculated.
Step 2.1 Derive the relations for logical data
model-I
(1) Strong Entity Types
(2) Weak Entity Types
(3) One-to-many (1:*) binary relationship types
(4) One-to-one (1:1) binary relationship types
(5) One-to-one (1:1) recursive relationship types
(6) Many-to-many (*:*) binary relationship types
(7) Superclass/ Subclass relationship types
(8) Complex relationship types
(9) Multi-valued relationship types
(1) Strong Entity Types
For each strong entity in the data model, Create a
relation that includes all the simple attributes of
the entity.
For composite attributes, such as name, include
only the ingredient of simple attributes namely,
fName and lName in the relation.

For example composition of the staff relation is:


Staff (staffNo, fName, lName, position, sex, DOB)
Primary Key staffNo
(2) Weak Entity Types
For each weak entity in the data model,
Create a relation that includes all the simple attributes of
that entity.

The primary key of a weak entity is partially or fully derived


from each owner entity.

So the identification of the primary key of a weak entity


cannot be made until after all the relationships with owner
entity have been mapped
(2) Weak Entity Types-I

For example the weak entity Preference is initially mapped


to the following relation:

Preference (prefType, maxRent)


Primary Key None (at present)
(3) One-to-many (1:*) binary relationship
types

For each 1:* binary relationship, the entity on the ‘one


side’ of the relationship is designated as parent entity and
the entity on the many side is designated as the child
entity.

To represent this relationship post a copy of the primary


key attribute of the parent entity into the relation
representing the child entity to act as a foreign key.
(4) One-to-one (1:1) binary relationship
types
Creating relations to represent a 1:1 relationship is slightly
more complex as the cardinality cannot be used to help
identify the parent and child entities in a relationship.

The participation constraints are used to help decide


whether it is best to represent the relationship by combining
the entities involved into one relation or by creating two
relations and posting the copy of the primary key from one
relation to the other.
One-to-one (1:1) recursive relationship
types
How to create relations to represent the following
participation constraints:

(a) Mandatory participation on both sides of 1:1


relationship
(b) Mandatory participation on one side of 1:1 relationship
(c) Optional participation on both sides of 1:1 relationship
(a) Mandatory participation on both sides of 1:1
relationship
In this case combine the entities involved into one relation and choose
one of the primary keys of the original entities to be the primary key of
the new relation, while the other (if one exists) is used as an alternate
key.

The Client states Preference relationship is an example of a 1:1


relationship with mandatory participation on both sides. In this case
choose to merge the two relations together to give the following Client
relation:
Client (clientNo, fName, lName, telNo, prefType, maxRent,
staffNo)
Primary Key clientNo
Foreign Key staffNo references Staff(staffNo)
(b) Mandatory participation on one side
of 1:1 relationship
In this case identify the parent and child entities for the 1:1
relationship using the participation constraints.

The entity that has the optional participation in the


relationship is designated as the parent entity and the entity
that has mandatory participation in the relationship is
designated as the child entity.

A copy of the primary key of the parent entity is placed in


the relation representing the child entity.
(c) Optional participation on both sides
of 1:1 relationship
In this case the designation of the parent and child entities
is arbitrary unless find out more about the relationship that
can help a decision to be made one way or the other.

For example, Staff uses Car relationship with optional


participation on both sides of the relationship.

If there is no additional information to help select the parent


and child entities, the choice is arbitrary.

In other words have the choice to post the copy of the


primary key of the Staff entity to Car entity or vice versa.
Step 2.2 Validate Relations using
normalization

To validate the relations in the logical data model using


normalization.

It is sometimes disputed that a normalized database design


does not provide maximum processing efficiency.
Following points can be disputed:

A normalized design organizes the data according to its


functional dependencies. The process lies somewhere
between conceptual and physical design.

The logical design may not be the final design. If there are
specific performance criteria the physical design may be
different.
A normalized design is free of the update anomalies.

Modern computers are much more powerful than that


were available a few years ago. It is sometimes
reasonable to implement a design that gains ease of use
at the expense of additional processing.

To use the normalization a database designer must


understand completely each attribute that is to be
represented in the database.

Normalization produces a flexible database design that


can be extended easily.
Step 2.3 Validate Relations against
user transactions
Objective: To ensure that the relations in the logical data
model support the required transactions.

Check it against user requirement specification document.


It is previously checked in step 1.8.
Using the relations, the primary key/ foreign key links
shown in the relations, the ER diagram, and the data
dictionary, attempt to perform operation manually.

If resolve all the transactions then validated the logical


model against the user transactions. Otherwise try to find
the problem.
Step 2.4 Check Integrity
Constraints
In order to protect the database from becoming incomplete,
inaccurate or inconsistent.
Consider the following types of integrity constraints:

Required Data (not hold null values)


Attribute Domain Constraints
Multiplicity
Entity Integrity
Referential Integrity
General Constraints
Document all the integrity constraints.
Step 2.5 Review Logical Data Model
with User

Objective:

To review the logical data model with the users to ensure


that they consider the model to be a true representation of
the data requirements of the enterprise.
Step 2.6 Merge Logical Data Model into
Global Model (Optional Step)
Objective: To merge local logical data models into single
global logical data model that represents all user views of a
database.

The activities in this step include:


Step 2.6.1 Merge local logical data models into global
model
Step 2.6.2 Validate global logical data model
Step 2.6.3 Review global logical data model with users
Up to this point for each local logical data model we have
produced an ER diagram, a relational schema, a data
dictionary and supporting documentation that describes the
constraints on the data.

In this step to identify the similarities and differences


between the models and thereby help merge the models
together.
Some typical tasks in this approach are as follows:

(1) Review the names and contents of entities/relations


and their candidate keys

(2) Review the names and contents of relationships/foreign


keys.

(3) Merge entities/relations from the local data models.

(4) Include (with out merging) entities/relation unique to


each local data model.

(5) Merge relationships/foreign keys from the local data


models.
Some typical tasks in this approach are as follows:

(6) Include ( with out merging) relationships/foreign keys


unique to each local data model.

(7) Check for missing entities/relations and


relationships/foreign keys

(8) Check foreign keys

(9) Check integrity constraints.

(10) Draw the global ER/ relation diagram

(11) Update the documentation


Step 2.7 Check for future growth
Objective: To determine whether there are any significant
changes likely in the foreseeable/predictable future and to
assess/charge whether the logical data model can
accommodate/hold these changes.
Output of Logical Data Model
ER diagram
Relational Schema
Data Dictionary (supporting documents)

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy