COMP9120 Database Management Systems
Assignment 2: Database Application Development
Group assignment (16%)
Introduction
The objectives of this assignment are to gain practical experience in interacting with a relational database management system using an Application Programming Interface (API) (JDBC). This assignment additionally provides an opportunity to use more advanced features of a database such as functions.
This is a group assignment for teams of 3 members. It is assumed that you will continue in your Assignment 1 group. You should inform. the unit coordinator as soon as possible if you wish to change groups.
Please also keep an eye on your email and any announcements that may be made on Ed.
Submission Details
The final submission of your database application is due at 11:59pm on Sunday 20th October (Week 11). You should submit the items for submission (detailed below) via Canvas.
Items for submission
Please submit your solution to Assignment 2 in the ’Assignment’ section of the unit’s Canvas site by the deadline, including EXACTLY THREE files:
• An assignment coversheet as a PDF document (.pdf file suffix) which is available for download fromthis linkon Canvas.
• A SQL file (CSHschema.sql) containing the SQL statements necessary to generate the database schema and sample data. This must contain the original schema and insert SQL statements, and any stored procedures (functions) you may have added.
• AJava file (PostgresRepositoryProvider.java) containing the Java code you have written to access the database.
Your code should be your own, except for the scaffold code provided. You are strictly prohibited from using any generative AI tools, such as Microsoft Copilot or ChatGPT to complete any part of this assignment. Failure to comply with this policy may result in academic penalties as outlined in the academic integrity guidelines.
Task 1: The Central Sydney Hospital (CSH) System
In this assignment, you will be working with a modified version of the CSH database as described in Assignment 1. This assignment builds upon and partially use your work designing the CSH hospital database. More specifically, your task is to implement an interface, referred to as CSH system, through which a user interacts to access and manipulate the CSH database. Your main task in this assignment is to handle requests for reads and writes to the database using your User Interface (UI). We first describe the main features that the CSH system must include from a UI perspective, and then discuss where your database code needs to be implemented.
Logging In
The user is defined as any authorized administrator at the CSH hospital. The first formauser is presented with, when starting the CSH system, is the Login, as shown in Figure 1. This feature requires that the administrator enters their username and password to be validated prior to being successfully logged into the system. Security features such as password encryption/hashing is out of scope for this assignment. Once logged in, the user is taken to the admission list page to view their associated admissions.
Figure 1 - Login
Viewing Admission List
Once a user is logged in, they are shown a list of all their associated admissions, as shown below in Figure 2. This list must be ordered such that the most recently discharged admission appear at the top. The list is also sorted by patient full name in ascending order, and admission type name in descending order. Each admission has a type name, department, discharged date, fee, patient and condition. Each administrator is assigned a set of admissions to administer and review.
Figure 2 - Viewing Admissions List
Finding Admissions
A user can search through all admissions by entering a word or phrase (a ‘keyword’) in the field next to the Find button, as shown in Figure 3, and then clicking on Find. When such a keyword is specified, then the retrieved admissions and shown on the list are those that include this word or phrase in the admission type name, department name, patient’s full name or condition. The search is case insensitive. For example, given the search keyword ‘st’, Find will return all admission that include the keyword ‘st’ in the admission type name, department name, patient’s full name or condition. Searching with a blank/empty keyword field will show all of the logged in user’s associated admissions. Any search results returned must be ordered such that admissions without a discharged date at the top, then by discharged date in ascending order and patient’s full name ascending. The search results must exclude those admissions whose discharged dates are older than 2 years (from today’s date).
Figure 3 - Finding Admissions
Selecting an admission from the admission list will present details for that admission , as shown in Figure 2. The admission’s condition appears in the large text area in the bottom-right part of the form.
Adding an Admission
Users may also add a new admission by clicking on the Add Admission tab in the title bar. They may enter admission details such as admission type name, department name, discharged date, patient id and condition, in the popup dialog. Once the popup dialog appears, click on Add Admission button, as shown in Figure 4. A new admission will not be assigned a discharged date or fee.
Figure 4 - Adding an Admission
Updating an Admission
Users can also update an admission by modifying data in the admission details screen as shown in Figure 5, by clicking on Update Admission button.
Figure 5 - Updating an Admission
The Refresh/Reset button can be used to refresh the admission details from the database, allowing users to check that their changes have been made, or to see if an admission has been updated.
Database Interaction Code
The files that are needed for the Java version of assignment areas follows:
1. CSHschema.sql: a file which contains SQL statements you need to run to create and initialise the CSH database, before starting the application
https://canvas.sydney.edu.au/files/39291865/download?download_frd=1
2. Assignment2_JavaSkeleton.zip: a zip file encapsulating the Java project for the CSH system
https://canvas.sydney.edu.au/files/39291880/download?download_frd=1
To look through the CSH system code, you’ll need to import the Eclipse project archive file into Eclipse.
Please begin by trying to import the project into Eclipse using the steps below:
1) Right Click the zip file containing the assignment 2 archive > 7zip > Extract Here.
2) Start Eclipse and choose a new location for your workspace in a new folder.
3) Click on File > Import > General > Existing Projects into Workspace > Next.
4) Browse to the folder you extracted zip file to, and then click Select Folder.
5) Ensure the Assignment 2 Project is ticked in the Projects box and click Finish.
If you experience any difficulties importing the eclipse project, ask your tutor or lecturer for assistance.
Once you import the project in Eclipse, you should notice that there are 3 main packages in the solution: Presentation, Business, and Data. The UI (in the Presentation package) is currently coded to invoke logic in the business layer (eg: see AdmissionProvider class in the Business package),which in turn delegates responsibility for interacting with the database to an appropriate repository in the data layer (eg: see PostgresRepositoryProvider in the Data package). Notice that separating concerns in this way makes it easier to write a different RepositoryProvider in the data layer (eg: we could write a MySQLRepositoryProvider) if we wanted to change our database management system. In this assignment, you will mainly be working on writing the appropriate queries and SQL commands to fulfil the CSH system functionality described in Task 1; where these SQL commands and queries should be written in the PostgresRepositoryProvider. You should use the correct username/password details as specified in tutorial 7. The application’s main method can be found in the AdmissionTrackerFrame. class. You can run this main method to run the entire application by right clicking the AdmissionTrackerFrame. file on the Project Explorer > Run As > Java Application.
Task 2: Functions Implementation
Core Functionality
In this assignment,you are provided with a Java skeleton project that must serve as the starting point for your assignment. Your task is to provide a complete implementation for the file PostgresRepositoryProvider.java, as well as make any modifications necessary to the database schema (i.e., CSHschema.sql). Specifically, you need to modify and complete these five functions:
1. checkStaffLogin (for login)
2. findAdmissionsByAdmin (for viewing admission list)
3. findAdmissionsByCriteria (for finding admissions)
4. addAdmission (for adding an admission)
5. updateAdmission (for updating an admission)
Note that, for each function, the corresponding action and outcome should be implemented by issuing SQL queries to the database management system. If you directly output the result set, pre-process, manipulate and/or make changes to the input or output datasets using Java code or additional packages (libraries) i.e. without issuing SQL queries, you are considered as cheating, and you will get penalised heavily and most likely get zero point for the assignment.
No additional Java packages or libraries should be imported.
Marking
This assignment is worth 16% of your final grade for the unit of study. Your group’s submission will be marked according to the attached rubric.
Group member participation
If members of your group do not contribute sufficiently, you should alert the unit coordinator as soon as possible. The course instructor has the discretion to scale the group’s mark for each member as follows:
Percentage of contribution |
Proportion of final grade received |
< 5% contribution |
0% |
5 - 10% contribution |
20% |
11 - 15% contribution |
40% |
16 - 20% contribution |
50% |
21 - 24% contribution |
60% |
25 - 28% contribution |
80% |
29 - 30% contribution |
90% |
> 30% contribution |
100% |
Note: The above table assumes that each group will have 3 members, so, on average, around 33% contribution is expected from each member of the group. In special case, if a group has less than 3 members then the contribution percentage will be adjusted accordingly. You must justify your contribution percentage by providing a detailed explanation of your individual contribution on the assignment coversheet mentioned before. You must also regularly record and maintain a diary of your group meetings and discussions on Canvas. Furthermore, we may run random face-to-face interviews to understand and justify your contribution, if needed.
Marking Rubric
Your submissions will be marked according to the following rubric, with a maximum possible score of 16 points.
|
Part Marks (0 – 1.5 pts) |
Full Marks (2 – 2.5 pts) |
Login |
Can correctly login the user ‘JDOE’ and validate his username and password. |
All valid users can be logged in successfully, and unsuccessful user logins should be rejected. |
View Admission List |
Correctly list all admissions associated with user ‘jdoe’ in the correct order (see Figure 2) |
Correctly list all admissions associated with a logging user, in the correct order, for all possible username input from Figure 1. |
Find Admissions |
Correctly list admissions for keyword “st” (see Figure 3) |
Correctly list admissions for all possible keywords. |
Add Admission |
Can correctly add an admission to the database. |
Can correctly add all valid admissions to the database. Admissions entered with invalid details should be rejected. |
Update Admission |
Can correctly update the status of an admission. |
Can correctly update details of all admissions, ensuring the updated details for an admission are valid. |
Stored Procedure (Function) |
A couple of stored procedures (functions) are correctly created in the submitted SQL file. |
A couple of stored procedures (functions) are correctly created in the submitted SQL file, and correctly called in two of the five specified functions. |
|
No Marks (0 pt) |
Full Marks (1 pt) |
Record Keeping of Group Discussions |
One or more issues reported or found with group member contribution, or with maintaining records of group meetings and discussions regularly on Canvas. |
No issue reported or found with group member contribution. All group members participate and regularly maintain a diary of group meetings and discussions on Canvas. |
版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。