讲解CSC2041/42、辅导QOL留学生、讲解SQL编程语言、辅导SQL设计
- 首页 >> DatabaseCSC2041/42 Information Management/Modelling 2018/19
CSC2041/42 Information Management/Modelling
October 16th
, 2018
Group Assignment
This will be a group assignment. Each group will work as a team to produce one final result for the
project. Co-operation among members within a group is strongly encouraged. Each group should
work independently, and no collaboration is allowed across groups.
Submission Deadline: Thursday November 29th, 2018 by 12 noon. There will be no extensions.
There will be a separate email by Week 8 on how/where to submit.
Group Formation: Groups have been formed randomly using a computer program, and have been
published in a document group-allocations.pdf in QOL resources. Some details of group allocations
are also included in that document.
Problem Statement: Queen’s Accommodation have approached you to help build a database
management system that will enable them to keep track of their properties, tenants and employees.
The following is the context statement that they have provided:
Queen’s Accommodation (QA) enables new employees joining Queen’s University Belfast to settle in
quickly by providing them high-quality accommodation in the vicinity of the university. QA also
arranges for accommodation for guest visitors to the university who come for short periods of stay at
Belfast. QA owns several buildings, each of which have a distinct address including post code. There
are several apartments within each of those buildings. Each apartment in a given building is assigned
an apartment number that is unique within that building (but not necessarily across different
buildings). QA wants to keep track of the number of bedrooms, the number of bathrooms and the total
area (in square feet) for each apartment. The system manages information for different kinds of
people. As of now, QA manages two disjoint categories of people: tenants and employees. For each
person, the system would maintain emergency contact information, specifically, the name and contact
number of a person to be contacted. Each person is identified by a unique ID, and has information
consisting of their first name and last name.
For each tenant, it is necessary to record their bank account number, since rent needs to be collected
every month. For each employee, the application will keep track of their monthly salary. Employees
may be managers or technicians (or both). Each manager has an office located in one of the
apartments owned by QA. Each manager manages at least one apartment, and each apartment must
have a manager. For each technician, the system would keep track of the skills they have; which may
be one or more of the following: “carpentry”, “plumbing”, “electrical”.
To rent an apartment from QA, tenants must sign a lease agreement. A least agreement is a formal
contract, identified uniquely by an ID, signed by one or more tenants (as may be the case with
roommates) to lease an apartment. It includes the start date and expected duration of occupation (in
terms of number of months), as well as the monthly rent charged for the apartment. The lease
agreement is also signed by any one of the managers at QA. The system keeps track of all (expired
and live) lease agreements signed so far. Similarly, even if a tenant ceases to be one, her details are
not purged from the system in anticipation of future custom.
This assignment has four tasks:
CSC2041/42 Information Management/Modelling 2018/19
(i) E-R Modeling: Generate an E-R diagram for the above database project for Queen’s
Accommodation.
The output of this stage will be an E-R diagram (1 page) and a list of constraints or
assumptions (if any) that you have made in the course of designing the E-R diagram (1 page
max). Feel free to make reasonable and intuitive assumptions, but do list them.
(ii) Database Design: Design the relational database for the task. You need to decide things such
as the attributes in each table, the primary key and foreign keys, and make design decisions
such as whether there are any redundant tables that can be reduced into other tables.
The output of this stage will be in the form of table schemas (relational schemas). An example
relational schema for a simple table would be “table1(attr1, attr2, attr3)” that indicates that the
table contains three attributes, with two of them (the underlined ones) forming the primary
key. For each table, you would also include information mentioning the entity sets and
relationship sets you have modelled in the table, foreign keys, and optionally, any remarks
that would help convey your thought process. This can occupy up to 1 page in your report.
Additionally, create two files:
createdbx.sql: The script for creating the tables where x should be replaced by your group
number (e.g., createdb6.sql for Group 6 and createdb56.sql for Group 56)
cleandbx.sql: The script for cleaning up (i.e., dropping) all the tables you have created.
Once again, x refers to the group number.
Note: Be aware of foreign key constraints while writing up cleandb.sql, and ensure you drop
the tables in a valid order. If your script does not execute well (e.g., throws an error due to
foreign key constraints), marks would be deducted.
(iii)SQL Querying: Think of 4 real-world and reasonably complex scenarios of querying the
database (e.g., find those tenants who have stayed in two different buildings within the same
year [note: do not use exactly this example query]), and design SQL queries for those
scenarios. For each scenario, give a verbal description of the query, and provide an SQL
statement for the query. You are also encouraged to give verbal descriptions to aid
understanding of the SQL query itself; e.g., for SQL statements with multiple nested queries,
you may include verbal descriptions of what each of the nested queries do. Each scenario
along with the SQL query should be described completely in one page (note that the SQL
query with good indentation can itself take a significant amount of page space). Thus, the
response for this section would be up to 4 full pages. Additionally, the following files need to
be provided:
insertdbx.sql: This script would insert sample data into the tables created in createdb.sql
querydbx.sql: This script would contain the 4 SQL queries. It is expected that the
insertdbx.sql is rich enough that each of the queries would give some tuples in the result.
Note: Do ensure that you enter enough data into your tables through insertdb.sql so that your
queries return non-null result sets even if they are fairly complex and involve many joins.
(iv) Coping with Changes: Queen’s Accommodation would like to evolve as time goes by, and
significantly expand its services. For example, QA may find that it is running short of
apartments to fulfil the requests it gets, and decide to expand by acquiring apartments on long
lease from private owners in Belfast, and offer them to their clientele (i.e., QUB visitors and
staff). Think of a reasonably sophisticated scenario like the above (note: please do not use
exactly the above scenario) and produce a report on how you would address such an
expansion plan and detail the changes you may need to make to your system. You only need
to verbally describe the changes, and the design choices you may have to make in order to
CSC2041/42 Information Management/Modelling 2018/19
support the expansion plan you have chosen to address. Think of this as a report to a database
expert detailing the nature and complexity of the effort needed to address the particular QA
expansion plan you have chosen. Be concise and to the point. The full report for this task,
comprising the description of the chosen expansion scenario and the means to address it,
should fit in 1 page.
(v) Question: Which was the one entity set or relationship set from the problem description that
you found hardest to model in the E-R Modeling task. Why do you think you found that hard
to model? [This task is unassessed/unmarked.]
Assignment Material: As indicated over the various sections above, the final output from the
assignment would be the following:
Report named reportx.pdf (x should be replaced by the group number) structured as the
following:
o Page 1: Cover Page, with information of the group members (student numbers, as
well as e-mails)
o Page 2: E-R Diagram (Ref: Task (i))
o Page 3: List of Constraints and/or Assumptions in E-R Diagram Design (Ref: Task
(i))
o Page 4: Database Design (Ref: Task (ii))
o Pages 5, 6, 7 and 8: SQL Querying (Ref: Task (iii) – each one should be 1 page max.)
o Page 9: Coping with Changes (Ref: Task (iv))
o Page 10: Answer to hardness question (Ref: Task (v))
o Page 11: Individual Contributions Record [Refer below]
Note: These task-wise sub-limits on pages need to be respected. Any violations on report
format or section limits would be penalized by up to 10% of total allocated marks.
Set of Scripts: 4 files named as the following (where x is the group number):
o createdbx.sql
o cleandbx.sql
o insertdbx.sql
o querydbx.sql
Individual Contributions Record: The final page in the project report, as indicated above, would be
an individual contributions record, which would be in the form of a table as below.
Group
Member
St. Number
Task (i) Task (ii) Task (iii) Task (iv) Group
Member
Totals
1234567 10 10 10 50 80
4531245 15 … … … …
… 20 … … … …
… 5 … … … …
… 40 … … … …
… 10 … … … …
100 100 100 100
While most of the table above is self-explanatory, the main information is noted below. There would
be one row in the table for each group member, who is identified by the student number. Each of the
four tasks are identified by a column. Each task has 100 contribution points, which need to be divided
CSC2041/42 Information Management/Modelling 2018/19
across the members of the group; the numbers in each column should total 100. The total points in
each row are recorded separately in the column titled Group Member Totals.
Assessment: The first four sections carry marks in the proportion 3:3:3:1; thus, the ER model
accounts for 30% of marks, whereas the coping with changes accounts for 10%. The fifth section is
not marked. There will be one final score for each group. The individual marks will be arrived at by
multiplying the final score for the group by a contribution factor. The contribution factor would be
determined using the Individual Contributions Record, and will be directly related to individual
contributions reported therein.
Support: The demonstrators assigned to the module will be available to help with the project to
answer specific queries (e.g., requests for clarifications on the problem statement etc.) during the
practical sessions or by email at csc2041@qub.ac.uk or csc2042@qub.ac.uk ; these mailboxes are
monitored by demonstrators, who will respond to your email. Please note that questions on design
decisions (e.g., do you think X can be made a separate entity set/table?) will not be encouraged since
that would give be disadvantageous to the groups who decide to figure it out themselves. The list of
demonstrators and contact information may be found in the demonstrators.pdf document on QOL.
Important Points to Note:
Report Formatting: Please use the A4 page size (choosing it in Microsoft Word is shown in
the screenshot below), and use the Times New Roman font with a minimum font size of 11pt
(larger font sizes are fine, but they reduce the amount of text you can fit within your page
limits). Additionally, you should use at least 1-inch (2.54cm) margins on all four sides, which
maps to the “Normal” page margin setting in Microsoft Word (screenshot below). Any
violations of recommended report formatting or non-adherence to task-wise page limits
(mentioned earlier) may be penalized by up to 10% of total allocated marks.
File Naming: As mentioned already, all files (reports and scripts) need to be named with the
group number as the final part of the name. For example, Group 9 would name its report as
report9.pdf. There should be no leading 0s; i.e., do not use filenames such as report09.pdf.
Submission: The final submission should be in the form of a zip file comprising the 5 files
described in the “Assignment Material” section above. The zip file should be named using the
above convention as assignmentx.zip (e.g., assignment9.zip). You will be provided directions
as to how to submit the assignment, by Week 8.
ER Diagram: For the ER diagram, follow the formatting conventions that have been
discussed in the lectures and included in the slides. Different textbooks use very different
CSC2041/42 Information Management/Modelling 2018/19
conventions, so be careful of making sure that you adhere to the formatting conventions that
we have discussed.
Clarity: Since we will not have an oral presentation, the report forms the primary means of
evaluation. Thus, the onus is on you to ensure that there is no ambiguity in the report (for
example, name attributes well). Lack of clarity that would allow for misinterpretation could
mislead the evaluator and thus lead to loss of marks.
Updates to this Assignment Document: This document may be updated in course of time to
include additional information (we do not expect to make changes or remove content from the
document); so, please check on QOL for updates to the document. Updates will be numbered
separately, and older versions will not be deleted.