Course 2023-2024 a.y.

20591 - COMPUTER PROGRAMMING AND DATABASE SYSTEMS

Department of Decision Sciences

Course taught in English
Go to class group/s: 23
DSBA (8 credits - I sem. - OB  |  SECS-S/01)
Course Director:
FABRIZIO IOZZI

Classes: 23 (I sem.)
Instructors:
Class 23: MAREK ELIAS


Mission & Content Summary

MISSION

The goal of the course is to provide the students with a wide range of skills and knowledge in computation and data management/analysis, which are extensively used throughout the whole education program. While not strictly mandatory, some previous exposure to computer programming (and in particular to the Python language) is highly recommended for this course.

CONTENT SUMMARY

  • Python programming: basic and advanced programming techniques.
  • Python scientific modules
  • Object-oriented programming.
  • Relational and non-relational databases 
  • Parallel and distributed computation (MapReduce).
  • Large scale data analysis with PySpark.

Intended Learning Outcomes (ILO)

KNOWLEDGE AND UNDERSTANDING

At the end of the course student will be able to...
  • Describe fundamental programming strategies.
  • Describe the functioning principles of database systems.

APPLYING KNOWLEDGE AND UNDERSTANDING

At the end of the course student will be able to...
  • Develop advanced object-oriented Python code
  • Develop code for algorithmic problem solving.
  • Organize and Use large-scale databases.

Teaching methods

  • Face-to-face lectures
  • Exercises (exercises, database, software etc.)

DETAILS

- Face-to-face lectures will contain both theoretical and applied parts. During the applied part of the lecture, the instructor will solve, together with the class, some exercises pertaining to the concepts discussed in the theory section. Then, after a few guided exercises, students can apply autonomously the techniques illustrated during the course, and they are encouraged to propose and discuss their solutions with the rest of the class. 
- Exercises consist in programming assignments to be done in class under the supervision of the Instructor and the Teaching Assistants, or at home. Solving the assignments improves understanding of the theoretical concepts and complements them with hands-on knowledge of the programming tools and techniques.

 


Assessment methods

  Continuous assessment Partial exams General exam
  • Written individual exam (traditional/online)
x   x

ATTENDING AND NOT ATTENDING STUDENTS

Students can take the exam in two ways:

  • with assignments and a short general exam taken in only one of the two Winter sessions. The short exam contains two parts: one about Python and the other about Databases. If the short exam is passed in both parts, then the final grade will come from the assignments' grade (50%) and the short general exam grade (50%). If either of the two parts is not passed, the overall exam is not passed.
  • with the complete general exam, worth 100% of the final grade.

 

All assignments and exams consist of programming exercises to be solved in the computer room. The programming exercises aim to assess the understanding of fundamental programming strategies and the knowledge of database systems. Collectively, the exercises will test the ability of students to develop advanced Python code, using  object-oriented techniques, for algorithmic problem solving. Moreover, they will test for the ability of organizing and managing large-scale databases.


Teaching materials


ATTENDING AND NOT ATTENDING STUDENTS

The textbooks are communicated prior to the start of the course. Handouts of each lecture and sample codes are provided.

Last change 22/05/2023 22:59