Professional Documents
Culture Documents
Documentation To Be Printed Final (Main)
Documentation To Be Printed Final (Main)
The history of our campus Wolkite University doesn’t exceed much greater than 4 or 5 years
(doesn’t include its construction period). B/c it is a small aged and less experienced university,
WKU has experienced a lot of difficulties in many aspects including the problem we are trying
to solve right now i.e. the problem of not having automated schedule system. By the way,
compared with other experienced universities and university collages, we can point out the
following issues as a highly noticeable issues in Wolkite University:
The points, which we listed above are just introductions to the issues experienced in the past 5
years in Wolkite University. If we try to create a list of problems in the past 4 or 5 years of
WKU history, then tons of papers won’t be enough.
There are some gradual changes in WKU in the past few years though. Some new systems are
being introduced, thanks to CCI department students and lecturers, they are trying to introduce
new systems which can minimize a lot of hard work and do work efficiently!
There were efforts in changing the manual systems into more accurate, automatic, efficient, user
friendly and computerized systems in the past few years, and it is still going very well.
1
SPECIFIC AND GENERAL OBJECTIVE OF OUR PROJECT
Before going to the specific and general objectives of our database system, it is better to let the
reader know what is it that we are taking about? What exactly is the project that we are
working on?
It is better to explain what our project’s concerns using a table so that the answer for the above
questions is answered in a well-organized and neat way.
THE PROJECT
Name of the project Schedule System For Wolkite University
What abilities does It has the abilities to store automatically generated
the database have? or manually created schedules in a well-organized
and in such a way that data retrieval is easy and
user friendly.
Is it useful? Yes! It is. It minimizes time waste and overlapping.
When we came to the main point, as the question suggests, our objective or aim should be both
specific and general and yes we have a general and specific objective.
SPECIFIC OBJECTIVE
Our specific objective is just to give a solution for the current issue in scheduling a lecture and
laboratory sessions (periods) to a specific time in such a way that there are no overlapping periods,
no time assigned more than the credit hours assigned for that subject.
GENERAL OBJECTIVE
We’ve separated our general objectives into phases. We did this in order to make our general
objective manageable and time table based.
2
Continued
OUR GENERAL OBJECTIVE (SEPARETED IN PHASES)
PHASE TIME (IN OBJECTIVE
THE NEXT...)
Make the project came true. Test the project and fix
1 30 Days issues if found. Try to integrate the database with
other application programs. (For adding
functionalities)
2 2 Months Make a fully functional Database System with a high
accuracy in doing its job.
3 3 – 6 Months Try to distribute it to the end users for testing
purpose.
End users may be:
Universities
High schools
Any other organizations that may need an
automated schedule system.
4 7 Months Collect user experience and add extra features.
5 10 – 12 Months Try to merge the whole system into other related
software systems and create a larger system.
Therefore, we can summarize our general objective into the Other Objectives
following statement: Develop:
Our program’s general objective is to create a highly Accurate
qualified and useful system that is capable of doing what Close to Perfect
the end user required it to do in a satisfying, fast, easy High Speed
way. And for the future, merge the system with other High Quality
related systems in order to create an all-in-one system. User Friendly
Trust Worthy
System.
3
DETAIL ANALYSIS OF THE EXISTING SYSTEM
Before going to the details, we have to make This problem still exists. By that, we mean
sure that one point is clear. We’ve tried to for instance,
analyze the existing system deeply but we At the current times, we can point out the
haven’t got all the information we need following issues as a major drawbacks of
because some of the information we need was the existing system.
not given to us simply because it was not The students may not have any idea
publicly available for everyone who needed it. which schedule is correct and which
When we came back to the main point, the schedule is not.
existing system, which is the one applied in Because there are sudden changes in
order to solve the issue we are taking about schedules, this arises ambiguity in
(i.e. the schedule system) is of course an such a way that a student may not
automated system. By automated system, we exactly know which schedule to
mean that the existing system uses software, follow, which schedule to left
database concepts and more in order to behind.
implement a schedule system. Although it is Because a lot of overlapping exists,
an automated system, it has a lot of there are confusions in both students
drawbacks. and lecturers.
Let us take for example the last year’s As of this days in Wolkite University,
scenario (2014, 2007 G.C): As we’ve seen, issues described above still exist.
there was a lot of corrections to the schedule
time table because it has a lot of overlapping.
As we can remember there was at least one or
two changes to the schedule every week for Generally, the existing system has a lot of
almost a month and a half. This is a big drawbacks and problems as described
problem which is not often expected from above.
automated computer systems. Note: we tried to get information about how
exactly the existing system works but this
information was not available to us.
4
STATEMENT OF THE PROBLEM
We’ve prepared two statements to explain what the problem is. One of the statement is in a short
form and the other explains the problem in a clearer and brief way.
STATEMENT 1
The first statement for the problem we are facing is:
There is a problem of not having a fully functional scheduling and time tabling
system in Wolkite University. So design a database system which can address
this issue.
STETEMENT 2 (THE BRIEF ONE)
STATEMENT
OF THE PROBLEM
The database keeps the class schedule timetable data. The database
holds the courses given to students, the instructor that teaches the
courses, the sections where courses are given. The instructor teaches
some specific course at specific time, day at some specific class room
(section). The database may contain some extra features such as
information about the manager which is controlling some specific
department, students class rooms etc. Some attributes contained by
the database include instructor’s personal information such as name,
SSN etc., course description such as: course name, course code, course
load etc. The database also contains other entities and attributes. This
are discussed latter.
5
STAKE HOLDERS OF THE SYSTEM
Currently, our stake holders are units (organs) found in Wolkite University, which are
working on the scheduling process and course time tabling. These units currently use the
system that we talked earlier (in section 3 of this text). As described, these are the stake
holders of our system when the final product is released.
But as described in section 2 (specific and general objective section of this text), for the
future stake holders of our system may increase. By the time we release a fully functional
and general purpose scheduling system, our stake holders can be:
High schools
Universities
Elementary and Junior schools
Other organizations that may need a general purpose scheduling system
Even our system’s stakeholders can be individuals. i.e. individuals may use the scheduling
system for their personal use.
For the future the system may be a general purpose scheduling system. So its application
area may grow even further so as the stakeholders. So it may be hard to predict the
stakeholders of the system for the future because of the wide application area of the system.
6
METHODOLOGIES THAT WE USED TO GATHER INFORMATION
The first thing that we did before the 1. The first method that we used to gather
information gathering process is find out what information is ask the end-users what exactly do
information do we exactly need in order to they need.
accomplish this project, what things are helpful We go to places that we believe our end
and what things are not, what are the things that users may exist.
need more priority than the others, etc. We asked our end-users questions that
are specially prepared for them. We ask
For instance, before we started the information
them both individually and in a group
gathering process we point out the following manner.
things that we believed are helpful for our 2. We give questionnaires for some students to
project. point out what issues exist in the existing
What is the currently being used system.
system? a. The questionnaires ask the readers what
What drawbacks does the existing they have experienced from the existing
system have? system. May be good or may be bad.
What are the good things that the b. The questionnaires also ask the readers
existing system have? to suggest what should be corrected in
the existing system.
What things can we use and what things
3. We, the system developers also gathered to
that we have to left from the existing analyze the existing system in a professional
system? way so that we get a better idea about the
What are the major users of our system? existing system and a better understanding of
What our end users need? what our new system should be.
What are the best way to follow in order 4. We asked some senior students (senior students
to make our system stable and user which lasted in this campus longer than we did)
friendly? etc. to tell us some background/history about the
After we point out necessary points like the ones organization (Wolkite University) that we are
listed above, then we started the information working with.
gathering process. Although the above points are the main methods we
used to gather information, we used other
During the information gathering process we
information gathering methods like one-on-one
used the following methods that we believed are interviews, group interviews, facilitated sessions,
necessary in the information gathering process. prototyping, etc. in order to gather information.
7
BUSINESS RULE AND CONSTRAINTS
8
BASED ON OUR BUSINESS RULE…
9
Continued… ENTITY RELATIONSHIP RELATIONSHIP CONSTRAINTS ATTRIBUTES
MIN –
RELATIONSH RELATIONSH PART
CARDINALITY MAX
NO. ENTITY IP IP ICIPA ATTRIBUTES TYPE
RATIO (entity’s
TYPE WITH TION
side)
1. Name char
1 Collage Contains Department FULL 1:N (1,N)
2. Code varchar
4. Year int
10
ER - DIAGRAM
11
DESCRIPTION OF THE ER DIAGRAM
Introduction In this section we are going to explain every relationship types and relationship constraints in a
clear manner.
We want the reader to know that in order to make our system, the ‘Teaches’ relationship type and
the ‘Section’, ‘Instructor’, and ‘Course’ entities were enough. All other things that we need to make a
fully functional schedule system like, checking whether there is overlapping, automatic class
assignment, etc… are done by the software that work with the database.
12
THE ‘CONTAINS’ RELATIONSHIP TYPE AND ITS CONSTRAINTS
This relationship shows that 1 department may contain several courses. For instance: The
The ‘contains’ r/ship Software Engineering department contains many courses.
The (min, max) constraint for this relationship type is (1, N) in both side of the relationship.
This is because there is a minimum of one department to contain specific courses. And N number
of maximum departments that has courses in them. plus, there is a minimum of one course to be
contained by a specific department. And N number of courses to be contained by a department.
There is always a full participation in both sides. If there is a department, there must be a course
given by that department. And if there is a course, the vice versa works great.
13
THE RELATIONAL SCHEMA (RELATIONAL MAPPING)
DEPARTMENT
Code Name Collage Code Manager SSN
COURSE
Code Name Load Credit Hours Department Code
STUDENT
ID First Name Last Name Year Section Code
SECTION
Code Name Identifying Letter
INSTRACTOR
SSN First Name Last Name
TEACHERS
Instructor SSN Course Code Section Code Time Day Class Type
14
4. As we can clearly see in the above relational schema, the tables used in our database are already
NORMALIZATION in normal form. So we don’t need any normalization at all!