辅导CSE2DBF、讲解SQL程序语言、database system讲解、辅导SQL设计

- 首页 >> Database作业

CSE2DBF 2018

Assignment 2 (20%)

Due date: 11.59pm Friday, Week 5, 19 October

AIMS AND OBJECTIVES:

ü to perform queries on a relational database system using SQL;

ü to demonstrate an advanced knowledge of stored procedures, stored functions and triggers.

This is an individual Assignment. You are not permitted to work as a group when writing this

assignment.

Copying, Plagiarism: Plagiarism is the submission of somebody else’s work in a manner that gives

the impression that the work is your own. The Department of Computer Science and Information

Technology treats plagiarism very seriously. When it is detected, penalties are strictly imposed.

Students are referred to the Department of Computer Science and Information Technology’s

Handbook and policy documents with regard to plagiarism and assignment return, and also to the

section of ‘Academic Integrity’ on the subject learning guide.

No extensions will be given: Penalties are applied to late assignments (5% of total assignment mark

given is deducted per day, accepted up to 5 days after the due date only). If there are circumstances

that prevent the assignment being submitted on time, an application for special consideration may be

made. See Student Handbook for details. Note that delays caused by computer downtime cannot be

accepted as a valid reason for a late submission without penalty. Students must plan their work to

allow for both scheduled and unscheduled downtime.

SUBMISSION GUIDELINES:

All tasks must have proper comments (Tasks as headings) in one single notepad file.

All the tasks above are to be submitted in soft-copy format using the submission link provided

on LMS by 11.59 pm Friday, October 19th, 2018.

SUBMISSION CHECKLIST:

ü The relevant SQL queries for the ‘House2Home Franchise Application’ Database System;

ü The required stored procedures, stored function, and triggers.

Implement the following tasks using SQL Developer

Download the file H2HSchema.sql from the LMS site and run it on SQL Developer. This file

contains all the CREATE and INSERT statements you will need for this assignment.

To run the file, copy paste all codes onto SQL Developer and click on Run Script option to run the

entire set of commands

NOTE: YOU DO NOT NEED TO INSERT MORE DATA INTO THE TABLES.

The list of tables available for this assignment is the following:

STORE (StoreID, StoreAddress, WeekDaysHours, WeekendHours)

ACCOUNT (AccountNo., AccountName, Balance)

DEPARTMENT (DepartmentID, DepartmentTitle, NoOfEmployees, AccountNo,

StoreID, FranchiseTeamID)

WEEKLY_SALES_REPORT (ReportID, StartDate, EndDate, SaleAmount,

ComRate, ComAmount, BrandID, BName, BSaleAmount, TypeID, TName,

TSaleAmount, EmployeeID, Ename, ESaleAmount, EBonus,

DepartmentID)

FRANCHISE_APP (AppNumber, AppDate, DecisionDate, Status,

DepartmentID, TeamID)

EMPLOYEE (EmployeeID, Name, Phone, Email, Address, Gender, DOB,

JoiningDate, CentralOrLocalEmployment, EFTPOSID, CANumber,

DepartmentID)

CASUAL_EMPLOYEE (EmployeeID, HourlyRate)

PART_TIME_EMPLOYEE (EmployeeID, WeeklyHours, Salary)

FULL_TIME_EMPLOYEE (EmployeeID, LeaveDays, Salary, MemberID)

TEAM_MEMBER (MemberID)

SHAREHOLDER (S.H.ID, Name, Phone, Email, Address, NoOfShares,

MemberID)

TEAM (TeamID, TeamName, TeamLeaderID)

MEMBERSHIP (MemberID, TeamID, PercentageOfShare)

NOTE: PK is printed underlined and FK is printed italic in italics.

Task 1 [50 marks]

Using the tables provided above, provide SQL statements for the following queries.

a. Show the store information along with its departments for all stores that opens the latest

during weekend. [5 marks]

b. Show the name and address of all team members for store S001. [5 marks]

c. List the franchise application details for each department of H2H along with the department

id and title. Include the departments that have not received any application yet. [5 marks]

d. Show the team information and number of members for all successful franchise application.

[5 marks]

e. Show the details of the franchise application that took the longest time to reach a decision.

[5 marks]

f. List the team member details (including shareholder and employee details such as id, name,

phone and email) for all the team members who are part of a franchise team of a successful

application. For each of the members, also include the date on which their franchise

application was granted. [5 marks]

g. List the team member details (shareholder/employee details) who has the maximum credit to

his name, based on his percentage of share in the team and the positive account balance of the

franchising department. (Hint: account balance can be found in the Account table)

[10 marks]

h. Show the top 4 employees (name, salary earned) that have earned the highest salary from

January 2017 – December 2017. Assume that all casual employees work 12 hours per week

and there are 45 working weeks a year. [10 marks]

Task 2 [30 marks]

Provide the implementation of the following stored procedures and function. For submission, please

include both the PL/SQL code and an execute procedure/SQL statement to demonstrate the

functionality.

a. Write a procedure that takes two dates as input (a duration) and updates the commission amount

of every weekly report for which the start date falls under this duration. The commission amount

is the result of multiplication of sale amount and commission rate (%). The procedure also

generates an output in the following format for every affected row:

The commission amount for report <ReportID> has been updated to <ComAmount> dollars,

which is <ComRate>% of the total sale amount of <SaleAmount> dollars.

b. Write a procedure that takes an employee id as argument and lists the details of an employee’s

department and reporting boss. Note that an employee’s reporting boss is the person who has the

highest percentage of share in the franchise team. The reporting boss can be either a full-time

employee or a shareholder. If the reporting boss is a shareholder, display number of shares along

with contact details and if the boss is an employee, mention DOB, gender and joining date along

with the contact information.

c. Write a function that takes an employee id and a month-year (date of ‘MON-YYYY’ format) and

returns the total bonus amount the employee have earned by making exceptional sales during that

month. If the employee was not awarded a bonus for that month, the function should return zero.

For the execution of the function, write a simple SQL query that lists down all the employees and

their total bonus amount earned for the month of April 2018.

Hint: Although we did not maintain referential integrity constraint between EMPLOYEE and

WEEKLY_SALES_REPORT, you can safely assume that the employee listed as the best

performing employee in a sales report is a valid employee, who is present in the employee table.

[10 marks each]

Task 3 [20 marks]

Provide the implementation of the following triggers. For submission, please include both the

PL/SQL code and a DML statement (insert, update or delete) to demonstrate the trigger functionality.

a. A trigger that prevents a full-time employee from applying for a franchise if he/she has less

than 10 years of experience as an employee of H2H.

b. A trigger that automatically backs-up a weekly sales report when it is deleted. To preserve

the data, the trigger stores the deleted report into a backup table:

BackupReport (ReportID, StartDate, EndDate, SaleAmount)

[10 marks each]


站长地图