Introduction
Year: 3rd
Semester: 2nd
Credits: 7 ECTS
Hours/Week: 2h lectures, 3h practical
Lecturer: João Correia Lopes (JCL)
Teaching Language
Portuguese
Objectives, Skills and Learning Outcomes
This course aims to give the students the competences to design and develop information repositories in the Web using Object-relational database management systems and scripting languages.
After completing this course, the student will be able to:
- Elicit the requirements of an information system
- Identify the actors and their Use Cases
- Prepare Use Case Diagrams using UML
- Obtain the Domain Object Model
- Obtain the logical relational database schema
- Validate the relational schema based on functional dependencies
- Obtain the database physical schema
- Tune the logical relational schema
- Explore the database using the Object-Relational Database Management System PostgreSQL
- Write queries to the database using SQL
- Implement integrity constraints and triggers
- Define transactions
- Define an architecture for handling errors in the data accesses
- Set privileges of users and user groups
- Use the scripting language PHP and its libraries to build the user interface and business logic of the Web Application
- Obtain the user interface in XHTML
- Set presentation styles using CSS
- Validate integrity rules on data entry forms through the use of JavaScript
- Use the JavaScript library jQuery to interact with the document and to make AJAX requests
- Ensure that Web pages are obtained in accordance with the accessibility and usability standards
Program
- Development of a web application supported by a database: requirements gathering, design, modeling, implementation, testing and documentation.
- General notions of architecture of web applications using client scripting languages (JavaScript) and server languages (PHP). Models of representation of XML documents (DOM), use of Ajax framework and APIs for data access.
- Design of object-relational databases using data modeling languages (UML), the SQL language and procedural extensions to SQL.
- Identification and maintenance of business rules: on the interface (JavaScript), on the business logic and in the database (triggers); define transactions.
- General notions of usability and Web Design.
Main Bibliography
- R. Ramakrishnan, J. Gehrke, Database Management Systems, McGRAW-Hill International Editions, 3rd Edition, 2002, ISBN=0-07-246563-8. [Library]
Complementary Bibliography
- Jeffrey D. Ullman, Jennifer Widom, A First Course in Database Systems, Prentice-Hall, 2nd Edition, 2001, ISBN=0-13-035300-0. [Library]
- Russ LinkMiles, Kim LinkHamilton, Learning UML 2.0, O'Reilly, 2006, ISBN=978-0-596-00982-3. [Library]
- Jakob Nielsen, Designing Web Usability: The Practice of Simplicity, New Riders Publishing, Indianapolis, 2000, ISBN=1-56205-810-X. [Library]
Teaching Procedures
The lectures will be used for presentation of the scripts of the work and representative examples and for their discussion, for analysis of assessments and for brief introductions to the technologies used. The practical classes will be used for laboratory project development as a group project with the teacher as a consultant.
Software
- PostgreSQL
- PHP
- jQuery Library
- Smarty Library
- PEAR-MDB2 Library
- Enterprise Architect or Dia
Evaluation Type
Distributed evaluation without final exam.
Registered Evaluation and Occupation Components
Evaluation by assessments done during the semester, according to the rules published elsewhere.
Description | Type | Time (hours) | Conclusion date |
---|---|---|---|
Attendance (estimated) | Lectures | 70 | — |
User Requirements Document (RER) | Laboratory work or fieldwork | 27 | 2010/03/16 |
Database Specification Report (REBD) | Laboratory work or fieldwork | 27 | 2010/04/13 |
Architecture Document and Vertical Prototype (RAP) | Laboratory work or fieldwork | 27 | 2010/05/04 |
Product (P) | Laboratory work or fieldwork | 36 | 2010/06/15 |
Demonstration (A) | Laboratory work or fieldwork | 5 | 2010/06/17 |
Individual Performance (DI) | Laboratory work or fieldwork | 0 | — |
Total | 192 | — |
Admission to Exams
Minimum required to pass this course: 40% in each practical assignment.
Final Grade
Classification = 10% REI + 20% REBD + 20% RAP + 40% PA + 10% DI
Marks of any component of assessment may vary from element to element in the same group.
This course, given its laboratory nature is not eligible for evaluation in a single moment, so it cannot be replaced by taking an exam.
Special Assignments
There are no special works or tests.
Special Evaluation (Working Students, etc)
All students have the same evaluation.
Classification Improvement
Students may improve the mark in the subject's next edition.