System Development Life Cycle
System Development Life Cycle
System Development Life Cycle
System Development Life Cycle (SDLC) adheres to important phases that are essential
for developers, such as planning, analysis, design, and implementation, and are explained
in the section below. There are several System Development Life Cycle Models in
existence. The oldest model, that was originally regarded as "the Systems Development
Life Cycle" is the waterfall model: a sequence of stages in which the output of each stage
becomes the input for the next. These stages generally follow the same basic steps but
many different waterfall methodologies give the steps different names and the number of
steps seem to vary between 4 and 7. There is no definitively correct Systems
Development Life Cycle model, but the steps can be characterized and divided in several
steps.
The SDLC can be divided into ten phases during which defined IT work products are
created or modified. The tenth phase occurs when the system is disposed of and the task
performed is either eliminated or transferred to other systems. The tasks and work
products for each phase are described in subsequent chapters. Not every project will
require that the phases be sequentially executed. However, the phases are interdependent.
Depending upon the size and complexity of the project, phases may be combined or may
overlap.
Initiation/planning
To generate a high-level view of the intended project and determine the goals of the
project. The feasibility study is sometimes used to present the project to upper
management in an attempt to gain funding. Projects are typically evaluated in three areas
of feasibility: economical, operational, and technical. Furthermore, it is also used as a
reference to keep the project on track and to evaluate the progress of the MIS team. The
MIS is also a complement of those phases. This phase is also called the analysis phase.
Design
In systems design functions and operations are described in detail, including screen
layouts, business rules, process diagrams and other documentation. The output of this
stage will describe the new system as a collection of modules or subsystems.
Build or coding
Modular and subsystem programming code will be accomplished during this stage. Unit
testing and module testing are done in this stage by the developers. This stage is
intermingled with the next in that individual modules will need testing before integration
to the main project. Planning in software life cycle involves setting goals, defining
targets, establishing schedules, and estimating budgets for an entire software project.
Testing
The code is tested at various levels in software testing. Unit, system and user acceptance
testing are often performed. This is a grey area as many different opinions exist as to
what the stages of testing are and how much if any iteration occurs. Iteration is not
generally part of the waterfall model, but usually some occurs at this stage.
Types of testing:
System Design provides the understandings and procedural details necessary for
implementing the system recommended in the system study. Emphasis is on the
translating the performance requirements into design specifications. The design phase
is a transition from a user oriented document to a document oriented to the
programmers or database personnel.
Logical design
Physical design
A Data flow diagram shows the logical flow of system. For a system it describes the
input (source), output (destination) ,database (data stores), and procedures (data flow)
all in a format that meets the user’s requirement. When analysis prepares the logical
system design, they specify the user needs at a level of detail that virtually determines
the information flow into an out of the system and the required data resources. The
logical design also specifies input forms and screen layouts.
The activities following logical design are the procedure followed in the physical
design e.g., producing programs ,software ,file , and working system. Design
specifications instruct the user about what the system should do.
Output design is one of the most important features of the information system. When
the outputs are not of good quality the users will be averse to use the newly designed
system and may not use the system. There are many types of output, all of which can
be either highly useful or can be critical to the users,depending on the manner and
degree to which they are used.
Outputs from computer system are required to communicate the results of processing
to users. They are also used to provide a permanent hard copy of results for later
consultations. Various types of outputs required can be listed as below:
Interactive outputs, which involve the user is communicating directly with the computer,
it is particularly important to consider human factor when designing computer outputs.
End user must find outputs easy to use and useful to their jobs, without quality output,
user may find the entire system unnecessary and avoid using it. The term output in any
information system may apply to either printer or displayed information. During
designing the output for this system, it was taken into consideration, whether the
information to be presented in the form of query of report or to create documents etc.
other important factors that are taken into consideration are:
Format of each output was another important point taken into consideration.
Output media, for each output appropriate media is decided whether it will be
displayed on screen or taken to printer or both.
Other output design related specification, i.e., how frequently the output will be
generated, how many pages or sheets approximately it will keep up, what is its planned
use and output distribution to users are also taken into account.
These where a few major designing issues , which were taken into consideration while
while deciding the output specification for the system. As direct beneficiary of reports is
the user community , they were consulted constantly at every level . Formats and screen
design for various reports where identified, taking into account the user requirements.
Before finalizing these given to users for any improvement and suggestions .End users
issues taken into consideration were readability , relevance and acceptability .
Ones all the output reports to be generated by system where identified, they were given to
user for acceptance. For prototyping various outputs, final output models where created
with dummy data, before they where finalized
Output sources:
Tabular contents
Graphic format
Using Icons
Output Definition:
The output should be defined in terms of :
Types of outputs
Format-hardcopy,screen,microfilm, etc
Location-local,remote,transmitted,etc
Frequency-daily,weekly,hourly, etc
Data Items
The name given to each data item should be recorded and its characteristics described in
a standard form:
Number of characters
Input Design
The input Design is the link that ties the information system into the user’s world. Input
specifications describe the manner in which data enters the system for processing. Input
design features can ensure the readability of the system and produce results from accurate
data, or they can result in the production of erroneous information.
Input performa were designed, after a careful discussion with users. It was attempted to
cover all user requirements. Designed performa were given to user for anu suggestion and
final approval.
Input designs are aimed at reducing the changes of mistakes of errors. As the
human beings are prone to errors there is always a possibility of occurrence of chance of
errors. Adequate validation checks are incorporated to ensure error free data storage.
some of the data validation checks applied are as following:
Redundancy of data is checked. It means the records of primary key do not occur twice.
Whenever items are coded, input code is checked for it’s validly with respects to
several checks.
Utmost care has been taken to incorporate the validation at each stage of the system. E.g.
when entering records into employee information table for employee, it is checked that
whether the corresponding employee exits in the employee information table etc.,
Enough messages and dialogue boxes are provided while design screen, which does
guide user at the time of any errors, or at time of entry. This feature provides a user-
friendly interface to native users. It can be emphasized that input designs of HRRP is so
designed that is ensures easy and error free data entry mechanism. Once one is sure of
input data the output formatting becomes an routine work.
Software Design
The purpose of this phase is to plan a solution for the problem specified by the
requirement document. This is first step in moving from the problem domain to
solution domain. Designing activity is divided into two parts:
a. System Design
Its aims to identify the modules that should be in the system, the
specification of these modules and how they interact with each other to produce
the desired results.
b.Detailed Design
The internal goal of each of the module specified in the system design is
decided
DATABASE DESIGN
CODE DESIGN
The process of code is to facilitate the identification and retrieve of items of
information. the code should be simple and east to understandable. The codes where
designed in such a way that the features such as optimum human oriented use and
machine efficiency are unaffected.
For the code to be designed effectively, the following characteristics were also
considered while designing the code.
Uniqueness
Versatility
Stability
Simplicity
Consciousness
The code should be adequate for present and anticipated data processing for machine and
human use. Care was taken to minimize the clerical effort and computer time required to
continue operation.
PROCESS DESIGN
The process can be conceptualized in such a way to keep the methodology of main
module process with along with some auxiliary task, which will run concurrently with the
main program.
The top-down approach is maintained so as to keep track of the process, which
satisfies the maintenance reliability testing requirements. The concurrency of the data is
checked during data entry, by means of validation check for data in each field.