|SCIENTIFIC DISCIPLINARY SECTOR||INF/01|
Learn how to design databases, in particular relational, to support applications or adapt existing databases to the needs of new applications that have to interact with them; how to express queries and changes on relational databases and acquire the basic principles relating to internal organization and administration of data management systems - with specific reference to physical schema design, performance monitoring, concurrent execution of transactions and access control.
DESCRIBE the different phases in the design of relational databases, the data models used at both a conceptual and logical level, the design techniques used in the various phases.
UNDERSTAND how to check the quality of the proposed schemes, how to possibly improve them by eliminating redundancies and anomalies.
USE the techniques proposed for the design of a relational database to support an application, starting with user requirements.
UNDERSTAND how to express queries and modifications on relational databases.
DESCRIBE the constructs of relational languages (relational algebra and SQL) and their properties
USE relational languages (algebra and SQL) to query a database, SQL to express data manipulation operations and establish integrity constraints on data
ONLY 12 CFU:
USE the SQL language to express complex operations through functions and procedures, to express complex integrity constraints and operational rules through triggers
UNDERSTAND the basic principles relating to the internal organization and administration of data management systems, with specific reference to the design of the physical scheme, performance monitoring, concurrent execution of transactions and access control.
ANSWER questions on the basic principles relating to the internal organization and administration of data management systems.
Basics of: first-order logic, set theory, syntax and semantics of a language, programming, computer architecture and operating systems.
Mixed: The course includes lectures on all the topics covered, laboratory exercises using a relational data management system and integrative activities using AulaWeb.
For 12 CFU:
Barbara Catania, Giovanna Guerrini, Elena Ferrari. Sistemi di Gestione Dati - Concetti e Architetture. CittaStudi Edizioni, Utet Libreria, De Agostini Scuola, 2006.
Barbara Carminati, Anna Maddalena, Marco Mesiti. Sistemi di Gestione Dati - Esercizi. CittaStudi Edizioni, Utet Libreria, De Agostini Scuola, 2008.
Office hours: Appointment by email or by Microsoft Teams Office: Valle Puggia – 301
Office hours: Appointment by email or by Microsoft Teams Office: Valle Puggia – 327
GIOVANNA GUERRINI (President)
CHIARA ACCINELLI (Substitute)
FEDERICO DASSERETO (Substitute)
All class schedules are posted on the EasyAcademy portal.
The exam consists of the following parts:
Details on how to prepare for the exam for each topic will be given during the lessons.
The written exam consists of
a set of closed-ended questions on basic course topics. The objective of these questions is to ascertain an understanding of the main issues faced during the lessons.
a design exercise. The objective of this exercise is to verify that the student knows how to use the data models and the design methodology addressed during the course.
query specification exercises. The objective of these exercises is to verify that the student is able to formulate queries in the languages (relational algebra and SQL) addressed during the course.
The oral exam will consist of: (i) in-depth discussion of the solutions developed by the student for the project (ii) any theoretical and / or practical questions on topics covered in the teaching, with particular reference to the topics on which deficiencies have been highlighted in the written test or in carrying out the project. In general, the oral exam is aimed at assessing not only if the student has reached an adequate level of knowledge, but also if he has acquired the ability to critically analyze the problems of designing and querying a database, as well as the use of a DBMS, addressed in class.