The Database System Development Lifecycle
The Database System Development Lifecycle
The Database System Development Lifecycle
An information system not only collects, manages, and controls data used and generated by an
organization but enables the transformation of the data into information. An information system
also provides the infrastructure to facilitate the dissemination of information to those who make
the decisions critical to the success of an organization. The essential component at the heart of an
information system is the database that supports it. Typically, the stages of the information systems
lifecycle include: planning, requirements collection and analysis, design (including database
design), prototyping, implementation, testing, conversion, and operational maintenance. Of
course, in this book we’re interested in the development of the database component of an
information system. As a database is a fundamental component of the larger organization-wide
information system, the database system development lifecycle is inherently linked with the
information systems lifecycle.
For small database systems with a small number of users, the lifecycle need not be very complex.
However, when designing a medium to large database system with tens to thousands of users,
using hundreds of queries and application programs, the lifecycle can become extremely complex.
The following are the stages of the database system development lifecycle:
1. Database planning
Database planning means the management activities that allow the stages of the database system
development lifecycle to be realized as efficiently and effectively as possible.
A starting point for establishing a database project is the creation of a mission statement and
mission objectives for the database system. The mission statement defines the major aims of the
database system, while each mission objective identifies a particular task that the database must
support. Of course, as with any project, part of the database planning process should also involve
some estimation of the work to be done, the resources with which to do it, and the money to pay
1
Database Planning
System Definition
Requirements collection
& analysis
Database Design
Physical design
Implementation
Prototyping
Testing
Operational
maintenance
for it all. A database often forms part of a larger organization wide information system and
therefore any database project should be integrated with the organization’s overall IS strategy.
Database planning may also include the development of standards that govern how data will be
collected, how the format should be specified, what necessary documentation will be needed, and
2
how design and implementation should proceed. Standards can be very time-consuming to develop
and maintain, requiring resources to set them up initially and to continue maintaining them.
However, a well-designed set of standards provides a basis for training staff and measuring quality,
and ensures that work conforms to a pattern, irrespective of staff skills and experience. Any legal
or organizational requirements concerning the data should be documented, such as the stipulation
that some types of data must be treated confidentially or kept for a specific period of time.
2. System definition
Identification of the scope and boundary of the database system, including its major user views.
Before attempting to design a database system, it’s essential that we first identify the scope and
boundary of the system that we’re investigating and how it interfaces with other parts of the
organization’s information system. When defining the system boundary for a database system we
include not only the current user views but also any known future user views.
User view
Defines what is required of a database system from the perspective of a particular job (such as
Manager or Supervisor) or business application area (such as marketing, personnel, or stock
control).
A database system may have one or more user views. Identifying user views is an important aspect
of developing a database system because it helps to ensure that no major users of the database are
forgotten when developing the requirements for the new application. User views are also
particularly helpful in the development of a relatively complex database system by allowing the
requirements to be broken down into manageable pieces. A user view defines what is required of
a database system in terms of the data to be held and the transactions to be performed on the data
(in other words, what the users will do with the data). The requirements of a user view may be
distinct to that view or overlap with other views.
3
We then analyze this information to identify the requirements (or features) to be included in the
new database system. These requirements are described in documents collectively referred to as
requirements specifications for the new database system.
Requirements collection and analysis is a preliminary stage to database design. The amount of data
gathered depends on the nature of the problem and the policies of the organization. Identifying the
required functionality for a database system is a critical activity, as systems with inadequate or
incomplete functionality will annoy the users, and may lead to rejection or underutilization of the
system. However, excessive functionality can also be problematic as it can overcomplicate a
system, making it difficult to implement, maintain, use, and learn.
4. Database design
The process of creating a design that will support the organization’s mission statement and mission
objectives for the required database system.
Database design is made up of two main phases called logical and physical design. During logical
database design, we try to identify the important objects that need to be represented in the database
and the relationships between these objects. During physical database design, we decide how the
logical design is to be physically implemented in the target DBMS.
5. DBMS selection
The selection of an appropriate DBMS to support the database system.
If no relational DBMS currently exists in the organization, an appropriate part of the lifecycle in
which to make a selection is between the logical and physical database design phases. However,
selection can be done at any time prior to logical design provided sufficient information is available
regarding system requirements such as networking, performance, ease of restructuring, security,
and integrity constraints. Although DBMS selection may be infrequent, as business needs expand
or existing systems are replaced, it may become necessary at times to evaluate new DBMS
products. In such cases, the aim is to select a product that meets the current and future requirements
of the organization, balanced against costs which include the purchase of the DBMS, any
additional software/hardware required to support the database system, and the costs associated
with changeover and staff training. A simple approach to selection is to check off DBMS features
against requirements. In selecting a new DBMS product, there is an opportunity to ensure that the
selection process is well planned, and the system delivers real benefits to the organization.
6. Application design
The design of the user interface and the application programs that use and process the database.
We must ensure that all the functionality stated in the requirements specifications is present in the
application design for the database system. This involves designing the interaction between the
user and the data, which we call transaction design. In addition to designing how the required
4
functionality is to be achieved, we have to design an appropriate user interface to the database
system.
Transaction design
A transaction is an action, or series of actions, carried out by a single user or application program
that accesses or changes the content of the database.
The purpose of transaction design is to define and document the high-level characteristics of the
transactions required on the database, including:
■ data to be used by the transaction;
■ functional characteristics of the transaction (what the transaction will do);
■ output of the transaction;
■ importance to the users;
■ expected rate of usage.
7. Prototyping
At various points throughout the design process, we have the option either to fully implement the
database system or to build a prototype.
5
A prototype is a working model that does not normally have all the required features or provide
all the functionality of the final system. The purpose of developing a prototype database system is
to allow users to use the prototype to identify the features of the system that work well, or are
inadequate, and if possible to suggest improvements or even new features for the database system.
In this way, we can greatly clarify the requirements and evaluate the feasibility of a particular
system design. Prototypes should have the major advantage of being relatively inexpensive and
quick to build. There are two prototyping strategies in common use today: requirements
prototyping and evolutionary prototyping. Requirements prototyping uses a prototype to determine
the requirements of a proposed database system and once the requirements are complete the
prototype is discarded. While evolutionary prototyping is used for the same purposes, the
important difference is that the prototype is not discarded but with further development becomes
the working database system.
8. Implementation
The physical realization of the database and application designs.
On completion of the design stages (which may or may not have involved prototyping), we’re now
in a position to implement the database and the application programs. The database
implementation is achieved using the Data Definition Language (DDL) of the selected DBMS or
a graphical user interface (GUI), which provides the same functionality while hiding the low-level
DDL statements. The DDL statements are used to create the database structures and empty
database files. Any specified user views are also implemented at this stage. The application
programs are implemented using the preferred third or fourth generation language (3GL or
4GL). Parts of these application programs are the database transactions, which we implement
using the Data Manipulation Language (DML) of the target DBMS, possibly embedded within a
host programming language, such as Visual Basic (VB), VB.net, Python, Delphi, C, C++, C#,
Java, COBOL, Fortran, Ada, or Pascal. We also implement the other components of the application
design such as menu screens, data entry forms, and reports. Again, the target DBMS may have its
own fourth generation tools that allow rapid development of applications through the provision of
non-procedural query languages, reports generators, forms generators, and application generators.
Security and integrity controls for the application are also implemented. Some of these controls
are implemented using the DDL, but others may need to be defined outside the DDL using, for
example, the supplied DBMS utilities or operating system controls. SQL (Structured Query
Language) is both a DDL and a DML.
6
converts the data to the required format of the new database files. Where applicable, it may be
possible for the developer to convert and use application programs from the old system for use by
the new system. Whenever conversion and loading are required, the process should be properly
planned to ensure a smooth transition to full operation.
10. Testing
Testing is the process of running the database system with the intent of finding programming
errors.
Before going live, the newly developed database system should be thoroughly tested. This is
achieved using carefully planned test strategies and realistic data so that the entire testing process
is methodically and rigorously carried out. Note that in our definition of testing we have not used
the commonly held view that testing is the process of demonstrating that faults are not present. In
fact, testing cannot show the absence of faults; it can show only that software faults are present. If
testing is conducted successfully, it will uncover errors in the application programs and possibly
the database structure. As a secondary benefit, testing demonstrates that the database and the
application programs appear to be working according to their specification and that performance
requirements appear to be satisfied. In addition, metrics collected from the testing stage provide a
measure of software reliability and software quality. As with database design, the users of the new
system should be involved in the testing process. The ideal situation for system testing is to have
a test database on a separate hardware system, but often this is not available. If real data is to be
used, it is essential to have backups taken in case of error. Testing should also cover usability of
the database system. Ideally, an evaluation should be conducted against a usability specification.