Case study
You are employed as a Database Developer for a large IT development company. The company has been approached by a transport company called SmartMovers which has grown to a level where need to have an automated system to handle day today operational activities to meet customer demands. You are given the job to design and develop a database solution for SmartMovers to meet their business requirements.
The company transports chemical products from one location to another on behalf of registered customers. Customers are of three types namely Catogory1, 2 and 3. Each customer is given a unique customer number and his or her details have to be recorded in the system.
Each transport operation is called a job, which involves picking up one or more loads of the products from a customer requested start location and delivers it to a customer requested destination. A unique number is given for each job and for each load when they are created.
A Load is transported using a particular transport unit, which consists of a lorry, a driver, assistant, and a container (for carrying the product) A container is fixed to a trailer so it needs to be coupled to a lorry at the start of a Job. (Single container can transport only one chemical product due to safety requirements)
Payments for a job depends on customer type, product type (No Risk, High risk) and the load type (small, medium and large). Transport operations are run from 9 regional depots. Jobs are allocated to individual depots to service. Depots hold, manage and maintain their own transport units which are permanently allocated to them to service Jobs. Normally transport units are held at the base Depot they belong.
The final system should be able to provide the required information for management decision making and to handle daily operations efficiently and effectively.
Part 1.2
a. Explain data normalization with examples. Check whether the provided logical design in 1.1 is normalised. If not, normalize the database by removing the anomalies.
b. Design set of simple interfaces to input and output for the above scenario using Wireframe or any interface-designing tool.
c. Explain the validation mechanisms to validate data in the tables with examples.
Part 1.3
a. Check whether the given design (ERD and Logical design) is representing the identified user and system requirements to access the effectiveness of the design.
Part 2
Part 2.1
Develop the database system with evidence of user interface, output and data validations, and querying across multiple tables.
a. Develop a relational database system according to the ER diagram you have created (Use SQL DDL statements).
b. Provide evidence of the use of a suitable IDE to create a simple interface to insert, update and delete data in the database
c. Implement the validation methods explained in 1.2-part c.
d. Display the details payment with the job details and the customer details using Join queries
Part 2.2
a. Explain the usage of DML with below mentioned queries by giving at least one single example per each case from the developed database.
Select
Update
Delete
Note: - The queries you have selected should be meaningful and relevant to the given scenario.
Part 2.3
a. Explain how security mechanisms have been used and the importance of these mechanisms for the security of the database. Implement proper security mechanisms (EX: -User groups, access permissions) in the developed database.
Part 2.4
a. Explain the usage of the below SQL statements with the examples from the developed database
Group by
Order by
Having
Between
Where
Part 3
Part 3.1
a. Provide a suitable test plan to test the system against user and system requirements
b. Provide relevant test cases for the database you have implemented
Note:- Learner needs to give expected results in a tabular format and screenshots of the actual results with the conclusion
Part 3.2
a. Explain how the selected test data in 3.1 b) can be used improve the effectiveness of testing.
Part 3.3
a. Get independent feedback on your database solution from the non-technical users and some developers (use surveys, questioners, interviews or any other feedback collecting method) and make recommendations and suggestions for improvements in a separate conclusion/recommendations section.
Part 4
Part 4.1
a. Prepare a simple users' guide and a technical documentation for the support and maintenance of the software.
Part 4.2
a. Your technical documentation should include some of the UML diagrams (Use case diagram Class diagram, etc.), flow charts for the important functionalities, context level DFD and the Level 1 DFD
Part 4.3
a. Suggest the future improvements that may be required to ensure the continued effectiveness of the database system.
Attachment:- Case study.rar