KEMBAR78
Database | PDF | Computers
0% found this document useful (0 votes)
37 views40 pages

Database

Uploaded by

cba.pluto
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
37 views40 pages

Database

Uploaded by

cba.pluto
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 40

Chapter 1 Fundamental Concepts ................................................................................................................

2
Chapter 2 Characteristics and Benefits of a Database.................................................................................. 3
Chapter 3 Types of Database Models ........................................................................................................... 7
Chapter 4 Data Modelling ............................................................................................................................. 9
Chapter 5 The Relational Data Model......................................................................................................... 14
Chapter 7 Entity Relationship Model .......................................................................................................... 18
Chapter 8 Integrity Rules and Constraints .................................................................................................. 29
Chapter 9 ER Modelling .............................................................................................................................. 37

1
Chapter 1 Fundamental Concepts

A Database is a shared collection of related data which is used to support the activities of a
particular organization. A database can be viewed as a repository of data that is defined once and
then is accessed by various users. A database has the following properties:
It is a representation of some aspect of the real world; or perhaps, a collection of data elements
(facts) representing real-world information.

A database is logical, coherent and internally consistent.

A database is designed, built, and populated with data for a specific purpose.

Each data item is stored in a field,


A combination of fields makes up a table. For example: an employee table contains fields that
contain data about an individual employee

A Database Management System (DBMS) is a collection of programs that enable users to create,
maintain databases and control all the access to the databases. The primary goal of the DBMS is
to provide an environment that is both convenient and efficient for users to retrieve and store
information.

With the database approach, we can have the traditional banking system as shown in the
following image.

2
Chapter 2 Characteristics and Benefits of a Database

There are a number of characteristics that distinguish the database


approach with the file-based approach.

Self-Describing Nature of a Database System

A Database System contains not only the database itself but also the descriptions of data
structure and constraints (meta-data). This information is used by the DBMS software or
database users if needed. This separation makes a database system totally different from the
traditional file-based system in which the data definition is a part of application programs.

Insulation between Program and Data

In the file based system, the structure of the data files is defined in the application programs so if
a user wants to change the structure of a file, all the programs that access that file might need to
be changed as well. On the other hand, in the database approach, the data structure is stored in
the system catalog not in the programs. Therefore, one change is all that‟s needed.

Support multiple views of data

A view is a subset of the database which is defined and dedicated for particular users of the
system. Multiple users in the system might have different views of the system. Each view might
contain only the data of interest to a user or a group of users.

3
Sharing of data and Multiuser system

A multiuser database system must allow multiple users access to the database at the same time.
As a result, the multiuser DBMS must have concurrency control strategies to ensure several
users access to the same data item at the same time, and to do so in a manner that the data will
always be correct – data integrity.

Control Data Redundancy

In the Database approach, ideally each data item is stored in only one place in the database. In
some cases redundancy still exists so as to improve system performance, but such redundancy is
controlled and kept to minimum.

Data Sharing

The integration of the whole data in an organization leads to the ability to produce more
information from a given amount of data.

Enforcing Integrity Constraints

DBMSs should provide capabilities to define and enforce certain constraints such as data type,
data uniqueness, etc.

Restricting Unauthorised Access

Not all users of the system have the same accessing privileges. DBMSs should provide a
security subsystem to create and control the user accounts.

Data Independence

System data (Meta Data) descriptions are separated from the application programs. Changes to
the data structure is handled by the DBMS and not embedded in the program.

Transaction Processing

The DBMS must include concurrency control subsystems to ensure that several users trying to
update the same data do so in a controlled manner. The results of any updates to the database
must maintain consistency and validity.

4
Providing multiple views of data

A view may be a subset of the database. Various users may have different views of the database
itself. Users may not need to be aware of how and where the data they refer to is stored.

Providing backup and recovery facilities

If the computer system fails in the middle of a complex update process, the recovery subsystem
is responsible for making sure that the database is restored to the stage it was in before the
process started executing.

Managing information

Managing information means taking care of it so that it works for us, and is useful for the work
we are doing. The information we collect is no longer subject to “accidental disorganization” and
becomes more easily accessible and integrated with the rest of our work. Managing information
using a database allows us to become strategic users of the data we have.

We often need to access and re-sort data for various uses. These may include:

 Creating mailing lists


 Writing management reports
 Generating lists of selected news stories
 Identifying various client needs

The processing power of a database allows it to manipulate the data it houses, so it can

 Sort
 Match
 Link
 Aggregate
 Skip fields
 Calculate
 Arrange

So a database tracks data, finding the bits you need and processing them in the way you arrange
for them to be processed.

5
Because of the versatility of databases, we find them powering all sorts of projects. A database
can be linked to:

 A web site that is capturing registered users


 A client tracking application for social service organisations
 A medical record system for a health care facility
 Your personal address book in your e-mail client
 A collection of word processed documents
 A system that issues airline reservations

6
Chapter 3 Types of Database Models

High-level Conceptual Data models

Provide concepts that are close to the way people perceive data to present the data. A typical
example of this type is the entity relationship model which uses main concepts like entities,
attributes, relationships. An entity represents a real-world object such as an employee, a project.
An entity has some attributes which represents properties of entity such as employee‟s name,
address, birthdate. A relationship represents an association among entities, for example an
employee works on many projects. The relationship exists between employee and project.

Record-based Logical Data models

Provide concepts that can be understood by the user but not too far from the way data is stored in
the computer. Three well-known data models of this type are relational data model, network data
model and hierarchical data model.

 The Relational model represents data as relations or tables.


 The Network model represents data as record types and also represents a limited type of one to many
relationship, called set type.

The Hierarchical model represents data as a hierarchical tree structures. Each hierarchy
represents a number of related records. Here is the schema in hierarchical model notation.

7
8
Chapter 4 Data Modelling

Data Modelling is the first step in the process of database design. This step is sometimes
considered as a high-level and abstract design phase (conceptual design). The aims of this phase
is to:

 Describe what data is contained in the database (e.g. entities: students, lecturers, courses, subjects
etc.)
 Describe the relationships between data items (e.g. Students are supervised by Lecturers; Lecturers
teach Courses )
 Describe the constraints on data (e.g. Student Number has exactly 8 digits; a subject has 4 or 6 unit of
credits only)

The data items, the relationships and constraints are all expressed using the concepts provided by
the high-level data model. Because these concepts do not include the implementation details, the
results of the data modelling process is a (semi) formal representation of the database structure.
This result is quite easy to understand so it is used as reference to make sure that all the user‟s
requirements are met.

The third step is Database Design. During this step, we might have two sub-steps called
Database Logical Design which define a database in a data model of a specific DBMS and
Database Physical Design which define the internal database storage structure, file organization
or indexing techniques. The last two steps shown are Database Implementation and
Operations/Interfaces Building. These focus on creating an instance of the schema and
implementing operations and user interfaces.

In the database design phases, data is represented using a certain data model. The Data Model is
a collection of conceptual concepts or notations for describing data , data relationships, data
semantics and data constraints. Most data models also include a set of basic operations for
manipulating data in the database.
Degree of Data Abstraction

In this section we will look at the database design process in terms of specificity. Just as any
design starts at a high level and proceeds to an ever-increasing level of detail so does database
design. For example, when building a home, you start with how many bedrooms the home will
have, how many bathrooms, whether the home will be on one level or multiple levels, etc. The

9
next step is to get an architect to design the home from a more structured perspective. This level
gets more detailed with respect to actual room sizes, how the home will be wired, where the
plumbing fixtures will be placed, etc. The last step is to hire a contractor to build the home.
That‟s looking at the design from a high level of abstraction to an increasingly detailed level of
abstraction.

The database design is very much like that. It starts with users identifying the business rules,
database designers and analysts creating the database design, and then the database design is
physically created using a DBMS.
External models

 Is the user’s view of the database


 contains multiple different external views
 is closely related to the real world as perceived by each user

Conceptual model

 These models provide a flexible data structuring capabilities.


 Community view : the logical structure of the entire database
 Contains ‘What’ data is stored
 Shows relationships among data
 constraints
 semantic information (business rules – discussed later)
 security & integrity information
 A database is considered as a collection of entities (objects) of various kinds.

 Basis for identification and high-level description of main data objects, avoids details
 They are database independent. It does not matter what database you will be using.

Internal model

 Database is considered as a collection of fixed – size record.


 This model is closer to the physical level or file structure.
 Is a representation of database as seen by the DBMS.
 Requires the designer to match the conceptual model’s characteristics and constraints to those of the
selected implementation model.
 The entities in the conceptual model are mapped to the tables in the relational model.

10
 The three most well-known models of this kind are the relational data model, the network data model
and the hierarchical data model.

Physical model

 Physical representation of the database


 Lowest level of abstractions
 It is how the data is stored, dealing with
 Run-time performance
 Storage utilization & compression
 File organization & access methods
 Data encryption
 Physical level – managed by OS
 Provide concepts that describe the details of how data is stored in the computer’s memory

Data Abstraction Layer

In a pictorial view, you can see how the different models work together. Let‟s look at this from
the highest level; the External Model.

The External Model is the end user view of the data. Typically a database is an enterprise
system that serves the needs of multiple departments. However, one department is not interested
in seeing the other departments‟ data. E.g. Human Resource does care to view the Sales data.
Therefore, one user view will differ from another.

The External model requires that the designer subdivide a set of requirements and constraints
into functional modules that can be examined within the framework of their external models (i.e.
HR vs. Sales)

As a data designer you need to understand all the data so that you can build an enterprise wide
database. Based on the needs of various departments the conceptual model is the first model
created.

At this stage the conceptual model is independent of both software and hardware. It does not
depend on the DBMS software used to implement the model. It does not depend on the
hardware used in the implementation of the model. Changes in either hardware or DBMS
software have no effect on the database design at the conceptual level.

11
Once a DBMS is selected, you can then implement it. This is the Internal model. Here you
create all the tables, constraints, keys, rules, etc. This is often referred to as the Logical design.

The physical model is simply the way the data is stored on disk. Each database Vendor will have
their own way of storing the data.

Schemas

A schema is an overall description of a database and it is usually represented by the Entity


Relationship diagram. There are multiple subschemas which are representations of the external
models. To put it into perspective of one database:

 External Schemas : multiple

 multiple subschemas = multiple external views of the data


 Conceptual Schema : one only
 Data items, relationships & constraints – ER diagram
 Physical Schema : one only
 Record definitions, representation methods
 Access methods, indexes, hashing

Logical and Physical Data Independence

Data independence refers to the immunity of user applications to changes made in the definition
and organization of data. Data abstractions expose only those items that are important or
pertinent to the user. Complexity is hidden from the database user.

12
Physical data independence deals with hiding the details of the storage structure from user
applications. The application should not be involved with these issues, since there is no
difference in the operation carried out against the data.

The data independence and operation independence together gives the feature of data abstraction.
There are two types of data independence: Logical and Physical.
Logical data independence

The ability to change the logical (conceptual) schema without changing the External schema
(User View) is called logical data independence. For example, the addition or removal of new
entities, attributes, or relationships to the conceptual schema should be possible without having
to change existing external schemas or having to rewrite existing application programs.

In other words, if the logical schema changed, i.e. changes to the structure of the database like
adding a columns or other tables, should not affect the functioning of the application (external
views).
Physical data independence

This refers to the immunity of the internal model to changes in the physical model. The logical
schema stays unchanged even though changes are made to file organization or storage structures,
storage devices, or indexing strategy.

13
Chapter 5 The Relational Data Model

This data model is introduced by C.F.Codd in 1970. Currently, it is considered as the most
widely used data model.

The relational model has provided the basis for:

 Research on theory of data/relationship/constraint


 Numerous database design methodologies
 The standard database access language SQL
 Almost all modern commercial database management systems

The relational data model describes the world as “a collection of inter-related relations (or tables)

Fundamental concepts in Relational Data Model


Relation

A relation is a subset of the Cartesian product of a list of domains characterized by a name.


Given n domains denoted by D1, D2, …, Dn , r is a relation defined on these domains if
r⊆D1×D2×…×Dn. A relation can be viewed as a “table”. In that table, each row represents a
tuple of data values and each column represents an attribute.

Table

To put it simply, a table holds the data. A database is composed of multiple tables. The one
below shows a database with three tables.

14
Column

A database stores pieces of information or facts in an organised way. Understanding how to use
and get the most out of databases requires us to understand that method of organisation.

The principal storage units are called columns, or fields, or attributes. These will house the
basic components of data that your content can be broken down into. When deciding which
fields to create you need to think generically about your information. For example, drawing out
the common components of the information that you will store in the database, and avoiding the
specifics that distinguish one item from another.

Look at the following example of an ID card to see the relationship between fields and their data:

Domain

A domain is the original sets of atomic values used to model data. By atomic, we mean that each
value in the domain is indivisible as far as the relational model is concerned. For example:

 The domain of Marital status has a set of possibilities: Married, Single, Divorced

15
 The domain of day Shift has the set of all possible days : {Mon, Tue, Wed…}.
 The domain of Salary is the set of all floating-point numbers greater than 0 and less than 200,000.
 The domain of First Name is the set of character strings that represents names of people.

In summary, a Domain is a set of acceptable values that a column is allowed to contain. This is
based on various properties and the data type for the column. We will discuss data types in
another chapter.
Records

Just as the content of any one document or item needs to be broken down into its constituent bits
of data for storage in the fields, the link between them also needs to be available so that they can
be re-constituted into their whole form. Records allow us to do this. A tuple is another term
used for records.

A simple table gives us the clearest picture of how records and fields work together in the
database storage project. Records and fields form the basis of all databases.

The example above shows us how fields can hold a range of different sorts of data – this one has:

 An ID field: ordinal number. integer


 A Pubdate field: day/month/year. date
 An author field: Initial. Surname. text
 A title field: text.
 A body text field: text.

By creating fields especially for the sorts of data they will house, the database can sort them
intelligently. You can request a selection of records which are limited by their date – all before a
given date, or all after a given date or all between 2 given dates. Similarly you can choose to
have records sorted by date. What is happening here is that the database is reading the

16
information in the date field, not just as numbers separated by slashes, but rather as dates which
must be ordered according to a calendar system – because the field was set up as a date field.
You are commanding the database to sift through its data and organise it in a particular way.

Degree

The degree is the number of attributes. In our example above, the degree is 4.

Properties of Tables

 Table has a name that is distinct from all other tables in the database.
 There are no duplicate rows, each row is distinct.
 Entries in columns are atomic (no repeating groups or multivalued attributes)
 Entries from columns are from the same domain based on their data type:

number (numeric, integer, float, smallint,…)

character (string)

date

logical (true or false)

 Operations combining different data types are disallowed


 Each attribute has a distinct name
 sequence of columns is insignificant
 sequence of rows is insignificant

Terminology

We have used many different terms. Here is a summary. Alternative 1 is the most common.

17
Database Design

Chapter 7 Entity Relationship Model

The Entity Relationship Data Model (ER) has existed for over 35 years.

The ER model is well-suited to data modelling for use with databases because it is fairly abstract
and is easy to discuss and explain. ER models are readily translated to relations.

ER modelling is based on two concepts:

 Entities, that is, things. E.g. Prof. Ba, Course Database System.
 Relationships, that is, associations or interactions between entities.

E.g. Prof. Ba teaches course Database Systems

ER models (or ER schemas) are represented by ER diagrams.

The example database

For the next section we will look at a sample database called the COMPANY database to
illustrate the concepts of Entity Relationship Model.

This database contains the information about employees, departments and projects:

 There are several departments in the company. Each department has a unique identification, a name,
location of the office and a particular employee who manages the department.
 A department controls a number of projects, each of which has unique name, a unique number and
the budget.
 Each employee has name, an identification number, address, salary, birthdate. An employee is
assigned to one department but can join in several projects. We need to record the start date of the
employee in each project. We also need to know the direct supervisor of each employee.
 We want to keep track of the dependents of the employees. Each dependent has name, birthdate and
relationship with the employee.

18
Entity, Entity Set and Entity Type

An entity is an object in the real world with an independent existence and can be differentiated
from other objects

An entity might be

 An object with physical existence. E.g. a lecturer, a student, a car


 An object with conceptual existence. E.g. a course, a job, a position

An Entity Type defines a collection of similar entities.

An Entity Set is a collection of entities of an entity type at a point of time. In ER diagrams, an


entity type is represented by a name in a box.

Types of Entities

Independent entities, also referred to as Kernels, are the backbone of the database. It is what
other tables are based on. Kernels have the following characteristics:

 they are the ‘building blocks’ of a database


 the primary key may be simple or composite
 the primary key is not a foreign key
 they do not depend on another entity for their existence

Example: Customer table, Employee table, Product table

Dependent Entities, also referred to as derived, depend on other tables for their meaning.

 Dependent entities are used to connect two kernels together.


 They are said to be existent dependent on two or more tables.
 Many to many relationships become associative tables with at least two foreign keys.
 They may contain other attributes.
 The foreign key identifies each associated table.

19
 There are three options for the primary key:
 use a composite of foreign keys of associated tables if unique
 use a composite of foreign keys and qualifying column
 create a new simple primary key

Characteristic entities provide more information about another table. These entities have the
following characteristic.

 They represent multi-valued attributes.


 They describe other entities.
 They typically have a one to many relationship.
 The foreign key is used to further identify the characterized table.
 Options for primary key are as follows:
 foreign key plus a qualifying column
 or create a new simple primary key
 Employee(EID, Name, Address, Age, Salary)
 EmployeePhone(EID, Phone)

Attributes

Each entity is described by a set of attributes. E.g. Employee = (Name, Address, Age, Salary).

Each attribute has a name, associated with an entity and is associated with a domain of legal
values. However the information about attribute domain is not presented on the ER diagram.

In the diagram, each attribute is represented by an oval with a name inside.

Types of Attributes

There are a few types of attributes you need to be familiar with. Some of these are to be left as
is, but some need to be adjusted to facilitate representation in the relational model. This first

20
section will discuss the types of attributes. Later on we will discuss fixing the attributes to fit
correctly into the relational model.

Simple attributes are attributes that are drawn from the atomic value domains

e.g. Name = {John} ; Age = {23} , also called Single valued.

Composite attributes: Attributes that consist of a hierarchy of attributes

e.g. Address may consists of “Number”, “Street” and “Suburb” → Address = {59 + „Meek
Street‟ + „Kingsford‟}

Multivalued attributes: Attributes that have a set of values for each entity

e.g. Degrees of a person: „ BSc‟ , „MIT‟, „PhD‟

Derived attributes: Attributes contain values that are calculated from other attributes

e.g. Age can be derived from attribute DateOfBirth. In this situation, DateOfBirth might be
called Stored Attribute.

21
Keys

An important constraint on the entities is the key. The key is an attribute or a group of attributes
whose values can be used to uniquely identify an individual entity in an entity set.
Candidate key

 a simple or composite key that is unique and minimal

 unique – no two rows in a table may have the same value at any time
 minimal – every column must be necessary for uniqueness
 For example, for the entity
Employee(EID, First Name, Last Name, SIN, Address, Phone, BirthDate, Salary, DepartmentID)

Possible candidate keys are EID, SIN

FirstName and Last Name – assuming there is no one else in the company with the same name,
Last Name and DepartmentID – assuming two people with the same last name don‟t work in the
same department.

EID, SIN are also candidate keys


Composite key

 Composed of more than one attribute


 For example, as discussed earlier

First Name and Last Name – assuming there is no one else in the company with the same
name, Last Name and Department ID – assuming two people with the same last name don‟t
work in the same department.

22
 A composite key can have two or more attributes, but it must be minimal.

Primary key

 A candidate key is selected by the designer to uniquely identify tuples in a table. It must not be null.
 A key is chosen by the database designer to be used as an identifying mechanism for the whole entity
set. This is referred to as the primary key. This key is indicated by underlining the attribute in the ER
model.
 For example Employee(EID, First Name, Last Name, SIN, Address, Phone, BirthDate, Salary,
DepartmentID) – EID is the Primary key.

Secondary key

 an attribute used strictly for retrieval purposes (can be composite), for example: Phone number, Last
Name and Phone number, etc.
 all other candidate keys not chosen as the primary key
 An attribute in one table that references the primary key of another table OR it can be null.
 Both foreign and primary keys must be of the same data type
 For example: Employee(EID, First Name, Last Name, SIN, Address, Phone, BirthDate, Salary,
DepartmentID) – DepartmentID is the Foreign key.

Alternate key

 all other candidate keys not chosen as the primary key

Foreign key

 An attribute in one table that references the primary key of another table OR it can be null.
 Both foreign and primary keys must be of the same data type
 For example: Employee(EID, First Name, Last Name, SIN, Address, Phone, BirthDate, Salary,
DepartmentID) – DepartmentID is the Foreign key.

Nulls

This is a special symbol, independent of data type, which means either unknown or inapplicable.
(it does not mean zero or blank)

 No data entry
 Not permitted in primary key

23
 Should be avoided in other attributes
 Can represent
 An unknown attribute value
 A known, but missing, attribute value
 A “not applicable” condition
 Can create problems when functions such as COUNT, AVERAGE, and SUM are used
 Can create logical problems when relational tables are linked

NOTE: the result of a comparison operation is null when either argument is null. The result of
an arithmetic operation is null when either argument is null (except functions which ignore nulls)

PROBLEM: Find all employees (EMP#) in Sales whose salary plus commission is greater than
30,000.

SELECT emp# FROM salary_tbl

WHERE jobname = „Sales‟ AND

(commission + salary) > 30000 –> E10 and E12

This result does not include E13 because of the Null value in Commission. To ensure the row
with the null value is included, we need to look at the individual fields. By adding commission
and Salary for employee E13, the result will be a null value. The solution is shown below.

SELECT emp# FROM salary_tbl

WHERE jobName = „Sales‟ AND

(commission > 30000 OR salary > 30000 OR

24
(commission + salary) > 30000 ) –>E10 and E12 and E13

Entity Types
Existence Dependency

 An entity’s existence is dependent on the existence of the related entity.


 It’s existence-dependent if it has a mandatory foreign key. That is a foreign key attribute that cannot
be null.
 Spouse entity is existence dependent on the employee

Weak Entities

 These tables are existence dependent.


 They cannot exist without entity with which it has a relationship.
 Primary key is derived from the primary key of the parent entity
 The spouse table is a weak entity because its PK is dependent on the employee table. Without a
corresponding employee record, the spouse record could not exist

Strong Entities

 If an entity can exist apart from all of its related entities it’s considered a strong entity.

 Kernels are strong entities.


 A table without a foreign key is or a table that contains a foreign key which can contain NULLS is a
strong entity.

Relationships

These are the glue that holds the tables together. They are used to connect together related
information in other tables.
1:M relationship

 Should be the norm in any relational database design


 Relational database norm
 Found in any database environment

e.g. One department has many employees

25
Source:
1:1 relationship

 Should be rare in any relational database design


 One entity can be related to only one other entity, and vice versa
 Could indicate that two entities actually belong in the same table

e.g. A professor chairs one department and a department has only one chair.
1:1 Example:

 An employee is associated with one spouse, and one spouse is associated with one employee.
 Cannot be implemented as such in the relational model
 M:N relationships can be changed into two 1:M relationships
 Can be implemented by breaking it up to produce a set of 1:M relationships
 Can avoid problems inherent to M:N relationship by creating a composite entity or bridge entity
 A student has many classes and a class can hold many students.
 Implementation of a composite entity
 Yields required M:N to 1:M conversion
 Composite entity table must contain at least the primary keys of original tables
 Linking table contains multiple occurrences of the foreign key values
 Additional attributes may be assigned as needed

M:N relationships

Mapping M-N Binary Relationship Type: For each M-N Binary Relationship, identify two
relations A, B represent two entity type participating in R. Create a new relation S to represent R.
Include in S as foreign keys the primary keys of A and B and all the simple attributes of R. The
combination of primary keys of A and B will make the primary key of S.

26
M:N relationships

Unary Relationships (recursive)

One in which a relationship exists between occurrences of the same entity set

The two keys (primary key and foreign key) are the same but they represents two entities of
different roles relate to this relationship.

In some entities, a separate column can be created that refers to the primary key of the same
entity set.

Ternary Relationships

Mapping Ternary Relationship Type: For each n-ary ( > 2 ) Relationships create a new relation to
represent the relationship. The primary key of the new relation is the combination of the primary
keys of the participating entities that hold the N (many) side. In most cases of an n-ary

27
relationship all the participating entities hold a many side.

Relationship Strength

Relationship strength is based on how the primary key of a related entity is defined.

Weak Relationships (non-identifying relationship)

 Exists if the PK of the related entity does not contain a PK component of the parent entity.

 Customer(custid, custname)
 Order(orderID, custid, date)

Strong Relationship (identifying)

 Exists when the PK of the related entity contains the PK component of the parent entity.

 Course(CrsCode, DeptCode, Description)


 Class(CrsCode, Section, ClassTime…)

28
Chapter 8 Integrity Rules and Constraints

Constraints are a very important feature in a relational model. In fact, the relational model
supports well defined theory of constraints on attributes or tables. Constraints are useful because
they allow a designer to specify the semantics of data in the database and constraints are the rules
to enforce DBMSs to check that data satisfies the semantics.
Domain Integrity

Domain restricts the values of attributes in the relation and it is a constraint of the relational
model. However, there are real –world semantics on data that cannot specified if used only with
domain constraints. We need more specific ways to state what data values are/are not allowed
and what format is suitable for an attributes. For example, the employee ID must be unique, the
employee birthday is in the range [Jan 1, 1950, Jan 1, 2000]. Such information is provided in
logical statements called integrity constraints.

There are several kinds of integrity constraints:

Entity Integrity – Every table requires a primary key. The primary key, nor any part of the
primary key, can contain NULL values. This is because NULL values for the primary key means
we cannot identify some rows. For example, in the EMPLOYEE table, Phone cannot be a key
since some people may not have a phone.

Referential integrity – a foreign key must have a matching primary key or it must be null

This constraint is specified between two tables (parent and child); it maintains the
correspondence between rows in these tables. It means the reference from a row in one table to
other table must be valid. Examples of Referential integrity constraint:
Referential integrity Examples

In the Customer/Order database:

 Customer(custid, custname)
 Order(orderID, custid, OrderDate)

To ensure that there are no orphan records, we need to enforce referential integrity.

29
An orphan record is one whose foreign key value is not found in the corresponding entity – the
entity where the PK is located. Recall that a typical join is between a PK and FK.

The referential integrity constraint states that the CustID in the Order table must match a valid
CustiD in the Customer table. Most relational databases have declarative referential integrity.
In other words, when the tables are created the referential integrity constraints are set up.

In the Course/Class database:

 Course(CrsCode, DeptCode, Description)


 Class(CrsCode, Section, ClassTime)

The referential integrity constraint states that CrsCode in the Class table must match a valid
CrsCode in the Course table. In this situation, it‟s not enough that the CrsCode and Section in
the Class table make up the PK, we must also enforce referential integrity.

When setting up referential integrity it is important that the PK and FK have the same data types
and come from the same domain. Otherwise the RDBMS will not allow the join.
Referential Integrity in MS Access

In MS Access referential integrity is set up by joining the PK in the Customer table to the CustID
in the Order table.

30
Referential Integrity using Transact SQL (MS SQL Server)

CREATE TABLE Customer

( CustID INTEGER PRIMARY KEY,

CustName CHAR(35) )

CREATE TABLE Orders

( OrderID INTEGER PRIMARY KEY,

CustID INTEGER REFERENCES Customer(CustID),

OrderDate DATETIME )

The referential integrity is set when creating the table (Orders) with the FK.
Foreign Key Rules

Additional foreign key rules may be added, such as what to do with the child rows (Orders table)
when the record with the PK – the parent (Customer) is deleted or changed (updated). The
relationship window in Access shows two additional options for foreign keys rules. Cascade
Update and Cascade Delete. If they are not selected, the system would prevent the deletion or
update of PK values in the parent table (Customer) if a child record exists. The child record is
any record with a matching PK.

DELETE

- RESTRICT

– CASCADE

– SET TO NULL

UPDATE

- RESTRICT

– CASCADE

In some databases, an additional option exists when selecting the Delete option. That is „Set to
Null‟. In these situations, the PK row is deleted, but the FK in the child table is set to Null.
Though this creates an orphan row, it is acceptable.

31
Enterprise Constraints – sometimes referred to as Semantic constraints. They are additional rules
specified by users or database administrators. i.e. A class can have a maximum of 30 students. A
teacher can teach a maximum of 4 classes a semester. An employee cannot take a part in more
than 5 projects. Salary of an employee cannot exceed the salary of the employee‟s manager.

Business Rules

Another term we‟ve used is semantics. Business rules are obtained from users when gathering
requirements. The requirements gathering process is very important and should be verified by
the user before the database design is built. If the business rules are incorrect, the design will be
incorrect and ultimately the application built will not function as expected by the users.

Some examples of business rules are:

 A teacher can teach many students


 A class can have a maximum of 35 students
 A course can be taught many times, but by only one instructor
 Not all teachers teach classes, etc.

Cardinality

Expresses minimum and maximum number of entity occurrences associated with one occurrence
of related entity. Business rules are used to determine cardinality.

Relationship Participation

32
There are two sides to each of the relationships when it comes to participation. Each side can
have two options for participation. It is either 0 (zero), 1 (one), or many. The outer most symbol
represents the connectivity. i.e. one to many would be represented by

The inner most symbols represent the cardinality which indicates the minimum number of
instances in the corresponding entity. i.e. on the right hand side it is read as: minimum 1
maximum many. On the left hand side it‟s read as minimum 1 and maximum 1.

See below for more examples.


Optional

One entity occurrence does not require a corresponding entity occurrence in a relationship

This shows a zero or many. The many side is optional.

This can also be read as:

Right hand side: A customer can be in a minimum of 0 orders or a maximum of many orders.
Left hand side: The order entity must contain a minimum of one related entity in the customer
table and a maximum of 1 related entity.

This shows a zero or one. The 1 side is optional.

33
Mandatory

One entity occurrence requires a corresponding entity occurrence in a relationship


This shows one and only one. 1 side is mandatory.

This example shows one or many. The many side is mandatory.

34
So far we have seen that the right hand side can have a 0 (zero) cardinality and a
connectivity of many or one.

The left hand side can also have a cardinality of 0 (zero).

However, it cannot have a connectivity of 0 only 1 (as shown). The connectivity symbols show
maximums. So if you think about it logically, if the connectivity symbol on the left hand side
shows 0, then there would be no connection between the tables. The way to read the left hand
side is: The CustID in the Order table must be found in the Customer table a minimum of 0 and
a maximum of 1 time. The 0 means that the CustID in the Order table may be null. The left
most 1 (right before the 0 representing connectivity) says that if there is a CustID in the Order
table it can only be in the Customer table once. When you see the 0 symbol for cardinality you
can assume two things. The FK in the Order table allows nulls, and the FK is not part of the PK
since PKs must not contain null values.

Relationship Types

You may have noticed in the previous image is the dashed line that connects the two tables. This
is referred as the relationship type. It‟s either identifying or non-identifying. Please see the
section that discussed weak and strong relationships for more explanation. The only thing you
need to understand for this section is the way the relationship is depicted in the ERD. Identifying
relationships will have a solid line (PK contains the FK). The non-Identifying relationship does
not contain the FK in the PK.

35
36
Chapter 9 ER Modelling

One important theory developed for the relational model involves the notion of functional
dependency (fd). Like constraints, functional dependencies are drawn from the semantics of the
application domain. Essentially, fd‟s describe how individual attributes are related. Functional
dependencies are a kind of constraint among attributes within a relation and that have
implications for “good” relational schema design. Here we will look at:

 basic theory and definition of functional dependencies


 methodology for improving schema designs (normalization)

The aim of studying this is to improve understanding of relationships among data and to gain
enough formalism to assist practical database design.
Relational Design and Redundancy

Generally, a good relational database design must capture all of the necessary
attributes/associations and should do this with a minimal amount of stored information (it means
there is no redundant data).

In database design, redundancy is generally a “bad thing” because it causes problems


maintaining consistency after updates. However, it can sometimes lead to performance
improvements e.g. may be able to avoid a join to collect bits of data together.

Consider the following table defining bank accounts/branches:

Insertion anomaly

When we insert a new record, we need to check that branch data is consistent with existing rows.

37
Update anomaly

If a branch changes address, we need to update all rows referring to that branch.

Deletion anomaly

If we remove information about the last account at a branch (Downtown), all of the branch
information disappears

38
The problem is that after deleting the row, we don‟t know where the Downtown branch is
located and we lose all information regarding customer „1313131‟. To avoid these kinds of
update/delete problems we need to decompose the original table into several smaller tables
where each table has minimal overlap with other tables. Typically, each table contains
information about one entity (e.g. branch, customer, …)
The Bank Accounts tables should appear as follows

This will ensure that when branch information is added or updated it will only affect one record.
When customer information is added or deleted, the Branch information will not be accidently
modified or incorrectly recorded.

Another Example:

Employee Project Table

Assumptions: EmpID and ProjectID is a composite PK

Project ID determines Budget. i.e. Project P1 has a budget of 32 hours.

Let‟s look at some possible anomalies:

Add row {S85,35,P1,9)

39
Problem: Two tuples with conflicting budgets

Delete tuple {S79, 27, P3, 1}

Problem: Deletes the budget of project P3

Update tuple {S75, 32, P1, 7} to {S75, 35, P1, 7)

Problem: Two tuples with different values for project P1‟s budget

To fix this, we need a table for employees and a table for projects.

Tables with Data

1. No anomalies will be created if a budget is changed

2. No dummy values are needed for projects that have no employees assigned

3. If an employee‟s contribution is deleted, no important data is lost

4. No anomalies are created if an employee‟s contribution is added.

The best approach to creating tables without anomalies is to ensure tables are normalized and
that‟s accomplished by understanding functional dependencies (FD). FD ensures that all
attributes in a table belong to that table. In other words, it will eliminate redundancies and
anomalies.

40

You might also like