Systems Development Life Cycle (SDLC)
This chapter will provide you with an overview of the systems development process.
First we describe in detail the traditional Systems Development Life Cycle (SDLC),
encompassing the stages through which each system should pass, from the initial
survey to hand-over of the completed system.
Pressure for rapid development and future maintainability of systems has resulted in
a number of alternative approaches to systems development, ranging from
development by end-users, to the incorporation of formal methods to improve the
quality and efficiency of the development process.
Systems development could be seen as the simple process of writing programs to
solve the needs of the user. Unfortunately, the user knows what he wants but has no
technical expertise while the programmer understands the computer but not the user
environment.
This communication gap between the customer and the service provider must be
handled by an intermediary, the systems analyst. Broadly speaking therefore the
systems analyst translates user’s needs into detailed specifications for
implementation by the programmer.
Over the years the software manufacturing process has become more formalised:
“The basic idea of the systems development life cycle is that there is a well defined
process by which an application is conceived, developed and implemented.
The life cycle gives structure to a creative process. In order to manage and control the
development effort, it is necessary to know what should have been done, what has
been done, and what has yet to be accomplished. The phases in the systems
development life cycle provide a basis for management and control because they
define segments of the workflow which can be identified for managerial purposes and
specify the documents or other deliverables to be produced in each phase.” [Davis
and Olson, 1985].
The number of stages and names to describe those stages differ slightly between
organisations; but the SDLC normally covers the activities described below, each with
a primary purpose.
Preliminary Investigation
The preliminary investigation is carried out to determine the scope and objectives of
the new system and to investigate whether there is a feasible solution.
New applications normally originate from end-user requests and are weighed against
the other requests for IS resources before approval to develop the system is granted.
At this stage an analyst or small project team is authorised to investigate the real
potential of the new application.
During this brief study the analyst must investigate the problem and the existing
system sufficiently to be able to identify the true extent and purpose of the new
application. In order to ensure that the new system would be of greater benefit to the
organisation than other competing requests for proposals, a feasibility study must be
performed covering the following three major areas:
i. Economic feasibility to measure the costs and benefits of the new system.
ii. Technical feasibility to ensure that the organisation has sufficient hardware, software
and personnel resources to develop and support the proposed system.
Page 1 of 11
iii. Operational feasibility, the willingness and ability of management, users and
Information Systems staff in the organisation to build and use the proposed system.
PRELIMINARY INVESTIGATION
Understand the problem and test for
feasibility
ANALYSIS
Investigation to determine what the user requires
and
identify the most cost-effective solution
DESIGN
Develop specification of how the new
system will run
BUILDING
Build or program the new system
IMPLEMENTATION
Convert to the new system
MAINTENANCE
Ongoing enhancement and support of
the new system
Page 2 of 11
Issues such as the size and complexity of the new system and the skills and availability
of user and IS staff, will determine the level of potential risk to the organisation in
developing the system.
The output from this preliminary investigation is a statement of scope and objectives
(often termed the project charter) together with a feasibility report. This document is
submitted to management where a decision is made as to whether or not the
development project should continue.
Systems Analysis
In this stage the analyst investigates the needs of the user and develops a conceptual
solution to the problem.
One human failing we all tend to exhibit is to rush into proposing solutions before we
fully understand the problem we are trying to solve. It is therefore important for the
analyst to develop a broad, conceptual solution to the problem (what needs to be
done) prior to launching into the detailed physical design where we specify how the
system will work.
In the past, analysis tended to be very much a pragmatic affair with success more
dependent on the experience and capabilities of the analyst than on any formalised
approach.
The analysis phase should include the following discrete steps:
Understand how the existing system operates. This information can be obtained by
observing people at work, interviewing users, and studying procedure manuals and
other supporting documentation, questionnaires and visits to other organisations.
Document the current physical system. A major problem in the past was how to record
all the detail about the system. Most of it could be found only in the analyst’s head or
draft notes. Here the basic tools of structured systems analysis such as the data flow
diagram (DFD), the entity relationship diagram (ERD) and data dictionary (DD) can be
used to represent graphically and record the data and procedures.
Define the problem areas. These may include such issues as poor response times in
the existing system, poor presentation of current information, high costs or weak
controls in the current system, waste and sometimes duplication.
Identify new requirements. The analyst must attempt to identify new user
requirements and look for new and improved procedures that can be incorporated
into the system.
Identify possible solutions. Having derived objectives for the new system from the
previous stage, the analyst now develops a conceptual model of the new system in
conjunction with the user. This may involve the investigation of alternative physical
designs, such as whether to remain with the existing manual system, or to choose a
centralised or decentralised approach to the application.
The culmination of the analysis stage is the preparation of the formal user
requirement specification (URS) that incorporates a logical model of a system that will
meet the user’s requirements. A large proportion of the functional description and
data specifications is best communicated from the analysis stage to the design stage
through the graphic and electronic output from the structured tools used in the
analysis process (data flow diagrams, entity relationship models, decision trees and
the data dictionary).
Page 3 of 11
Again management is required to review the status of the project and to make its
go/no-go decision.
Systems Design
The analysis stage of the SDLC has clearly identified what must be done in order to
meet the user’s requirements. One important decision that must be taken at this point
is whether to “make or buy” the new software application.
In the past, most large organisations developed their own applications as no two
organisations were exactly alike, and they could afford the investment in systems
developed around their user’s needs. Today the picture is changing as custom-built
software is becoming very expensive to develop and even more so to maintain.
Computer applications are large, complex and integrated and many businesses have
become non-competitive because of their inability to develop systems that
adequately support their business activities.
On the reverse side, packages (pre-written software applications) are becoming more
common and can be customised to meet the needs of each organisation. With major
benefits in terms of speed of installation, cost, low maintenance and low risk, more
and more companies are switching to packaged applications software. It is at this
stage in the SDLC that the “make or buy” decision must be taken.
We have analysed our user’s requirements and can use these as selection criteria in
searching for an appropriate package to purchase and install. Where there is no
suitable package available we can still look to other innovative ways of obtaining the
software, such as hiring contract staff or appointing a software house to build the
system for us.
Purchasing pre-written software will obviously mean the detailed systems design,
coding and testing phases of the project are bypassed, depending on the need for
customisation of the final system.
The objective of the design stage is to determine exactly how the new system will
work, and to communicate this information in a document referred to as the detailed
systems specification.
If we take the analogy of an architect building a house, in the analysis stage, he has
determined the feasibility of the project and identified the owner’s requirements in
terms of the positioning of the house on the plot, size and architectural style, number
of rooms and so on. The architect may even have built a small model to demonstrate
the look and feel of the new dwelling. Once the owner is happy that the proposed
house meets his requirements, the architect must communicate the detailed design
to the builders. This would entail the drawing of a detailed plan of the house,
specifying exactly how every part of the building is constructed and defining
dimensions, materials, construction techniques etc.
We need to go through the same process when designing computer systems. This
includes the design of:
the technical platform on which the software will run. The new application may need
new hardware, operating systems software and network connections
output reports and enquiry screens-how the reports should appear after processing
input forms and data capture procedures
physical file and database layouts
description of the workings of each program module
Page 4 of 11
new clerical processes and procedures that will be required to interface with the new
system.
Whereas in the analysis stage the emphasis was on identifying the user’s needs with
little concern for the way the computer would be used, the design stage also requires
user involvement for the approval of detailed design, but the physical constraints are
also of major importance.
Gane and Sarson [1979] define the objectives of structured design as follows: “The
most important objective of design, of course, is to deliver the functions required by
the user. If the logical model calls for the production of pay cheques and the design
does not produce pay cheques, or does not produce them correctly, then the design
is a failure. But given that many correct designs are possible, there are three main
objectives which the designer has to bear in mind while evolving and evaluating a
design:
Performance. How fast the design will be able to do the user’s work given a particular
hardware resource.
Control. The extent to which the design is secure against human errors, machine
malfunction, or deliberate mischief.
Changeability. The ease with which the design allows the system to be changed to, for
example, meet the user’s needs to have different transaction types processed.
The output from systems design is a detailed design specification incorporating
technical, input, output, data and process specifications. In the past, much of the
information was communicated in written form which was difficult to understand and
often ambiguous. Imagine the builder having to construct a house from a written
description.
Like the output from analysis we have a number of innovative tools to help users and
developers understand and communicate the workings of the system. These include
data models and data dictionaries, screen and report layouts, structure charts and
pseudo-code.
Systems Build
In this stage we program the new system. If the system has been purchased “off-the
shelf”, this phase would consist of the customisation of the system-modifying the
system to match the entity’s business activities.
The success of the implementation stage is heavily reliant on the previous stages. If
the analysis stage was poorly enacted, the system may not be what the user requires.
Poor design will make it difficult for the programmer to construct the system, and it
may be inefficient and difficult to maintain.
However, if the required effort and expertise is invested in analysis and design, there
will be a precise specification of what to build available to the IS programmers and
technical staff.
Unlike the previous stages, the programming stage can be undertaken as a number of
separate tasks, performed in parallel. Programmers can code, data base
administrators set up the database, hardware suppliers install and test networks and
equipment, and we can begin to train the end-users to prepare them for the
implementation phase. With so much happening, and with the need for some tasks to
Page 5 of 11
be completed before others begin, the analyst must develop a detailed project
implementation plan to ensure tasks are scheduled and delays are quickly identified
and addressed. Programming includes the following steps:
i. database construction
ii. program coding and testing
iii. testing to check the system can handle expected loads and meets physical
performance criteria
iv. finalise manual procedures
Systems Implementation
This entails the transition of the completed system into the operational environment,
and includes the following tasks (some of which will already have been started in
earlier phases):
installation and testing of any new hardware, systems software and network
infrastructure
train users and operations staff
transfer data (data conversion) from the manual or old system to the new database
where necessary
perform acceptance testing. This requires careful planning to ensure all data flows,
error procedures, interfaces, controls and manual procedures are tested
complete project documentation
The change over carries some risk, as failure of the new system may result in the
organisation being unable to do business,
There are a number of approaches to converting from the old system to the new.
The least risky is to run the new system in parallel with the old until the new system is
stable. There is obviously a cost to running both systems.
Another approach is to convert one part of the organisation at a time (for example
one branch office at a time). This method (known as the pilot method) reduces risk
and allows the development team to focus on one area. This approach can cause some
integration problems as part of the organisation is running on the old system and part
on the new.
A similar approach is the phased implementation method where organisations
convert to a large system one step at a time. For example they may start with the stock
system, then implement debtors and finally the order entry system.
Some organisations use the big bang approach and just switch over from the old to
the new system. This option is obviously high risk as there is no system to fall back on
in an emergency.
Maintenance
Finally, resources will be required to maintain and enhance the system over its
operational life which can vary between 4 and 10 years.
There is normally a formal hand-over of the system from the project team to the
maintenance team. This will ensure that there is a defined time when the project is
completed and that all the required documentation is produced.
Page 6 of 11
There are many systems in existence that are still supported by the original developer;
and all knowledge of the system exists only in that individual’s head.
The problem is that when this person leaves (or worse gets run over by a bus), there
is no one with any knowledge of the system and the organisation is at risk.
Research has shown that this is the most expensive stage of the life cycle as program
bugs (as a result of poor design or bad coding and testing) or enhancements (poor
analysis of user’s requirements or changes to the business) require continual analysis
and programming effort.
Post-implementation Audit
When the new system has been in operation for a few months, a post-implementation audit
should be carried out. This audit must ascertain whether the project has achieved the initial
objectives specified in terms of:
meeting initial scope and objectives
anticipated costs and benefits to the organisation
user satisfaction with the new system
performance (response/turnaround time, reliability)
adherence to standards
quality of final product
project performance in terms of cost and time.
This exercise will help to highlight problems that require maintenance of the new system and
provide valuable feedback to IS management and project teams to assist in future
development exercises.
Alternative approaches to developing systems
Over the past 40 years, efforts have been made to improve the quality of new systems and to
reduce the time and effort expended in their development. The following section provides an
overview of some of the significant tools and techniques developed for this purpose.
1. Prototyping
One technique that has been incorporated successfully into the SDLC is prototyping.
As the name suggests a prototype is a mock-up or model of a system for review
purposes.
Looking at the traditional SDLC, one of the major problems is that the user is asked to
provide detailed requirements prior to the system being built.
Once a system is implemented he may find flaws in his original requirements or may
see the possibilities of a new and improved approach.
For applications such as general ledger and payroll, the requirements are normally
well understood (and usually standardised enough to suggest the use of packages) but
many other areas such as personnel are unstructured and would benefit from the
prototyping stage.
The two main approaches to the use of prototypes in the SDLC are:
i. Discovery prototyping where the analyst builds a skeleton of the final product in the
analysis stage of the project in order that the user may better understand the workings
of the final system.
The building and refining of the prototype is an iterative process between analyst and
user and stimulates discussion on the functionality of the final product.
Page 7 of 11
Once the analyst and user are happy that the system’s requirements have been
identified, detailed requirement specifications are developed and the prototype is no
longer required. In some instances the prototype may serve as the specification.
ii. Evolutionary prototyping where a working model is built with the intention of later
refining it into the operational system.
While this technique would appear to have great advantages in terms of productivity,
the original prototype is often thrown together and not properly designed.
Prototyping can offer IS developers many advantages in that it:
o assists in clarifying user’s requirements,
o improves user communication and commitment,
o should improve the functionality and quality of the user interface and will
assist in identifying problems earlier in the development life cycle.
Where prototyping can be problematic is that:
o it raises the user’s expectations that systems are quick to build and changes
are easy.
o In addition, there is a lack of experienced prototypers and quality prototyping
tools.
2. Joint Application Development (JAD)
One major problem in systems development projects is the lack of real
communication, understanding and consensus between users, management and the
development team.
Instead of the traditional one on one interviews spread over weeks and often months,
the JAD approach involves a series of highly structured workshops where stakeholders
focus on any one of the planning, analysis, design and implementation stages of the
life cycle.
One obvious advantage of this approach is a reduction in the time it takes to develop
systems.
However, the real benefits of JAD come from better user requirements through
improved communication and conflict resolution.
Successful JAD sessions often depend on the competence of the session leader
(termed the facilitator), the scribe (who is responsible for documenting the output
from the sessions), strong top management support and a mix of participants with
expertise and responsibility for the area under discussion
3. Computer Assisted Software Engineering (CASE)
There is a famous saying, “The cobblers children have no shoes.” and this is very
relevant to IS.
Here we have a classic example of a group of IS professionals, dedicated to
computerising the organisation in which they work, while developing these computer
systems via manual means.
CASE environments attempt to address this problem by offering a set of integrated
electronic tools for use in the SDLC.
During the first phase of system development, CASE products provide the analyst with
computerised tools to complete and document the analysis and detailed design stages
Page 8 of 11
of the development project by graphically modelling the data requirements and the
business process flows that the intended application must address.
These models attempt to give a visual representation of a part of the business
operations, following one of many modelling standards.
The resultant application model is then used as a blueprint for the actual
implementation in computer code.
The tools that are geared specifically for this modelling phase are referred to as upper-
CASE or U-CASE tools.
Lower-CASE tools specialise in the second phase of system development: the actual
generation of executable applications or advanced prototypes. This is typically
achieved through the use of a generic application generator, although CASE tools tend
to be independent of any specific database management system.
Integrated or I-CASE aims to automate both phases i.e. a combination of upper and
lower- CASE tools in one single package. Most CASE environments use an electronic
project dictionary as a repository and can include:
graphic tools for charting diagrams such as DFD’s, ERD’s and Structure charts
4th generation languages or application generators to assist with prototyping
data dictionary facilities to record and maintain data about data, processes and other
system details
quality control facilities to check specifications and code for correctness
code generators to reduce programming effort
spreadsheet models to assist with cost/benefit analysis
project management tools to plan, monitor and control the development cycle.
When CASE environments were originally developed in the mid 1980s, IS managers
viewed them as a possible “silver bullet” to resolve the growing demand for computer
systems.
The promise of CASE was better quality systems, reduced development time, enforced
standards and improved documentation.
As yet CASE tools have failed to make a major impact.
CASE environments are complex,
the cost of implementing CASE is high (both in terms of the CASE software and analyst
training)
and many organisations are looking to other solutions (packages and object
orientation) to resolve their applications backlog.
Using Information Systems
Many factors can affect the ability of an information system to fulfil its goal of
supporting business processes.
Before an information system is developed, its purpose must be aligned with the goals
of the business, a cost benefit study should be completed, and user requirements
must be carefully analysed to ensure that it will provide the appropriate functionality.
During the system development process, organisational standards need to be adhered
to in respect of the various deliverables of the SDLC and the overall IT architecture of
the organisation.
But over and above these planning and acquisition issues, the final measure of success
for an information system depends on how it is used – are employees happy to
Page 9 of 11
incorporate it into their data processing activities; does it deliver the information that
they need; is the integrity of information guaranteed; can human or technical
problems be identified and corrected? No matter how carefully a system has been
developed, there are still potential problems associated with its use in the real world,
which need to be included in an IS management strategy.
Change Management and Resistance to Change
One of the main reasons that information systems fail, is that users resist change.
Many individuals believe that their skills and experience will be of less value in an
automated environment, which threatens their job or status.
Users may refuse to adapt to new methods of working, or while using the new system
may attempt to undermine its efficiency.
Acceptance of the system can be significantly improved through the implementation
of a change management strategy.
During the systems analysis phase, users should be involved in the identification of
problems that occur in existing systems, and given the opportunity to express their
own information requirements.
If they are made aware of shortcomings in the old system and of how these will be
alleviated when the new system has been implemented, then they are more likely to
accept the change.
Where decisions need to be made between alternatives, users should be part of the
decision-making process rather than being presented with a unilateral solution.
The design phase of the SDLC involves the “make or buy” decision. The evaluation of
commercial packages should be done by a team that includes users as well as
managers and technicians, so that any operational concerns can be raised and
clarified.
If a system is to be developed in-house (or outsourced), then the users should be
consulted about the layout of screens for data capture, and the format of reports.
Finally, if the new system will result in changes to existing work procedures, the impact
should be discussed and any problems or training needs identified.
User training falls within the systems implementation stage of the SDLC, and should
involve more than just teaching users how to operate the new system.
They must also understand what the purpose of the system is, what benefits it is
expected to generate for the business, what problems could result if it is incorrectly
used, and the importance of their role in its successful implementation.
13.6 How IS Affects You
Every department of an organisation uses information technology in some way, and
even if you are not an IS major, IS is likely to be an important element of your future
career in commerce.
In finance and accounting, information systems are used to forecast revenues, plan
business activities, manage financial resources and audit the performance of the
organisation.
Page 10 of 11
In sales and marketing, information systems are used to determine the potential
market for new products, to plan advertising campaigns and predict sales revenues,
to determine product prices and manage customer relations.
Many of the processes in an organisation’s value chain can be enhanced through the
use of computer-based information systems, from procurement to manufacturing to
after-sales service. The operations manager who has a sound knowledge of
information technology will be able to apply it effectively in order to maintain
competitive advantage in the market.
Human resource management is no longer focused solely on employee record
keeping. The internet has become a powerful employment tool; company intranets
empower staff to manage their benefits, leave and training requirements. IT now has
an important role to play in the hiring and retention of staff.
Of course, if you intend becoming an IS specialist, then the development and
management of information systems will be central to your future career, and this is
only the beginning of your studies in the field of IS. Even if you focus on a particular
aspect of IS, such as database or network administration, you will need a solid
foundation of basic principles that will enable you to integrate your area of
responsibility with the goals of the business and the IT architecture that supports
them.
Page 11 of 11