Bazy danych I I-NI7O>BD-I
A. Wykłady - szczegółowe treści kształcenia:
1. Wprowadzenie, rodzaje i klasyfikacja baz danych, charakterystyka poszczególnych rodzajów baz danych, zastosowania baz danych, cechy, funkcje i wymagania stawiane bazom danych, przegląd nowoczesnych systemów RDBMS (Relational Database Management Systems).
2. Relacyjne bazy danych: wprowadznie i opis podstawowych pojęć (relacja, tabela, rekord, krotka, atrybut, domena, klucz podstawowy, klucz obcy, unikalność, ograniczenia integralnościowe, zapytanie, podzapytanie, widok, złączenie, operacje algebry relacji itp.), typy danych w MS SQL Server.
3. Podstawy tworzenia zapytań i programowania w języku T-SQL. Operatory zbiorowe. Złączenia (JOINs): krzyżowe, wewnętrzne, wielokrotne, zewnętrzne.
4. Projektowanie wyrażeń tabelowych: tabele pochodne, CTE, widoki, wbudowane funkcje zwracajace tabele.
5. Zaawansowane zagadnienia tworzenia zapytań: funkcje okna, przedstawianie danych, odwrotne przedstawianie danych, zbiory grupujące.
6. Modyfikowanie danych: wstawianie, aktualizacja, usuwanie, scalanie. Elementarne polecenia DDL – tworzenie i modyfikacja tabel.
7. Tworzenie tabel temporalnych. Struktury danych i indeksów w MS SQL Server.
8. Obiekty programowalne: zmienne, wsady, elementy kontroli przepływu wykonania, kursory, tabele tymczasowe, dynamiczny kod SQL, obsługa błędów.
9. Wprowadzenie do zagadnienia tworzenia funkcji definiowanych przez użytkownika, procedur składowanych oraz wyzwalaczy.
10. Zaliczenie wykładu (sprawdzian pisemny).
B. Ćwiczenia laboratoryjne:
1. Zajęcia wprowadzające – szkolenie BHP w laboratorium komputerowych, wyjaśnienie zasad obowiązujących w pracowni informatycznej. Wprowadzenie do środowiska zarządzania relacyjnymi bazami danych MS SQL Server. Przegląd przykładowych baz danych, wykorzystywanych w dalszej części zajęć laboratorium Bazy danych I. Utworzenie nowej bazy danych, a następnie tworzenie i modyfikacja tabel wg. zadanego schematu. Analiza działania poleceń CREATE DATABASE, CREATE TABLE, ALTER TABLE, DROP TABLE - tworzenie skryptów z wykorzystaniem wykorzystaniem graficznego interfejsu użytkownika (Miscrosoft SQL Server Managenet Studio)). Przegląd ograniczeń schematu relacyjnej bazy danych – krótka rekapitulacja materiału teoretycznego przedstawionego na wykładzie, dotycząca ograniczenia kluczy (ograniczenia PRIMARY KEY, FOREIGN KEY oraz UNIQUE).
2. Tworzenie i modyfikacja zapytań SQL do pojedynczych tabel. Składnia polecenia SELECT, wykorzystanie klauzuli WHERE (wprowadzenie pojęcia operatorów relacyjnych, arytmetycznych, teoriomnogościowych, logicznych), Wykorzystanie klauzuli ORDER BY do wyświetlania wyników zapytań w żądanym porządku.
3. Wyjaśnienie pojęcia agregacji danych (wykorzystanie klauzuli GROUP BY oraz HAVING), prezentacja dostępnych predefiniowanych funkcji agregujących (MIN, MAX, COUNT, AVG, SUM, STDEV, VAR), wyjaśnienie pojęcia „alias”, wprowadzenie predykatów DISTINCT i ALL, rozszerzających możliwości zapytań wybierających.
4. Wprowadzanie danych do tabel za pomocą polecenia INSERT, zastosowanie słowa kluczowego INTO oraz VALUES, wykorzystanie polecenia INSERT INTO … SELECT. Wprowadzanie zamian za pomocą polecenia UPDATE. Usuwanie danych z tabeli za pomocą polecenia DELETE.
5. Złączenia, krótkie przypomnienie materiału z wykładu na temat klauzuli JOIN, złączenie wewnętrzne (INNER JOIN), złączenie zewnętrzne (OUTER JOIN), złączenia zewnętrzne lewo- i prawostronne, złączenia pełne (FULL JOIN), złączenia krzyżowe (CROSS JOIN), pojęcie unii (UNION).
6. Sprawdzian pisemny nr 1. Zapytania rozszerzone, tworzenie podzapytań zagnieżdżonych i skorelowanych, tabele pochodne, operator EXISTS, mieszanie typów danych (funkcje CAST i CONVERT). Widoki proste i złożone, tworzenie, edycja i usuwanie widoków.
7. Procedury składowane – krótkie przypomnienie materiału przedstawionego na wykładzie, tworzenie (CREATE PROC), zmiana (ALTER PROC) i usuwanie (DROP PROC) procedur składowanych, określanie parametrów procedur.
8. Instrukcje (polecenia) sterujące przepływem programów (IF..ELSE, CASE, WHILE, WAITFOR, TRY/CATCH), pozostałe polecenia, instrukcje obsługi błędów, zagadnienie rekurencji przy tworzeniu procedur składowanych.
9. Funkcje definiowane przez użytkownika, tworzenie, zmiana i usuwanie funkcji. Wyzwalacze – przykłady różnych rodzajów wyzwalaczy, zastosowanie, wady i zalety, dobre praktyki tworzenia i stosowania wyzwalaczy.
10. Sprawdzian pisemny nr 2.
W cyklu 2021/2022-Z:
Tematyka zajęć skupia się na podstawowych zagadnieniach tworzenia i wykorzystania relacyjnych baz danych. Studenci zostają zapoznani z najważniejszymi pojęciami należącymi do teorii baz danych, klasyfikacją baz, ich strukturą oraz funkcjonowaniem mechanizmów silnika bazodanowego. W ramach zajęć przedstawiany i omawiany jest szczegółowo język SQL, jako podstawowe narzędzie przeznaczone do pracy z bazami danych. Ponadto prezentowane są zagadnienia dotyczące podstaw prawidłowego modelowania i tworzenia struktur bazodanowych z uwzględnieniem normalizacji tabel, integralności danych, wierności odwzorowania rzeczywistości oraz dobrych praktyk. Zarówno wykłady, jak i ćwiczenia prowadzone są w oparciu o środowisko zarządzania relacyjnymi bazami danych MS SQL Server. |
W cyklu 2022/2023-Z:
Tematyka zajęć skupia się na podstawowych zagadnieniach tworzenia i wykorzystania relacyjnych baz danych. Studenci zostają zapoznani z najważniejszymi pojęciami należącymi do teorii baz danych, klasyfikacją baz, ich strukturą oraz funkcjonowaniem mechanizmów silnika bazodanowego. W ramach zajęć przedstawiany i omawiany jest szczegółowo język SQL, jako podstawowe narzędzie przeznaczone do pracy z bazami danych. Ponadto prezentowane są zagadnienia dotyczące podstaw prawidłowego modelowania i tworzenia struktur bazodanowych z uwzględnieniem normalizacji tabel, integralności danych, wierności odwzorowania rzeczywistości oraz dobrych praktyk. Zarówno wykłady, jak i ćwiczenia prowadzone są w oparciu o środowisko zarządzania relacyjnymi bazami danych MS SQL Server. |
W cyklu 2023/2024-Z:
Tematyka zajęć skupia się na podstawowych zagadnieniach tworzenia i wykorzystania relacyjnych baz danych. Studenci zostają zapoznani z najważniejszymi pojęciami należącymi do teorii baz danych, klasyfikacją baz, ich strukturą oraz funkcjonowaniem mechanizmów silnika bazodanowego. W ramach zajęć przedstawiany i omawiany jest szczegółowo język SQL, jako podstawowe narzędzie przeznaczone do pracy z bazami danych. Ponadto prezentowane są zagadnienia dotyczące podstaw prawidłowego modelowania i tworzenia struktur bazodanowych z uwzględnieniem normalizacji tabel, integralności danych, wierności odwzorowania rzeczywistości oraz dobrych praktyk. Zarówno wykłady, jak i ćwiczenia prowadzone są w oparciu o środowisko zarządzania relacyjnymi bazami danych MS SQL Server. |
W cyklu 2024/2025-Z:
Tematyka zajęć skupia się na podstawowych zagadnieniach tworzenia i wykorzystania relacyjnych baz danych. Studenci zostają zapoznani z najważniejszymi pojęciami należącymi do teorii baz danych, klasyfikacją baz, ich strukturą oraz funkcjonowaniem mechanizmów silnika bazodanowego. W ramach zajęć przedstawiany i omawiany jest szczegółowo język SQL, jako podstawowe narzędzie przeznaczone do pracy z bazami danych. Ponadto prezentowane są zagadnienia dotyczące podstaw prawidłowego modelowania i tworzenia struktur bazodanowych z uwzględnieniem normalizacji tabel, integralności danych, wierności odwzorowania rzeczywistości oraz dobrych praktyk. Zarówno wykłady, jak i ćwiczenia prowadzone są w oparciu o środowisko zarządzania relacyjnymi bazami danych MS SQL Server. |
Koordynatorzy przedmiotu
<b>Ocena końcowa</b>
W cyklu 2022/2023-Z: student uzyskuje ocenę końcową, jeżeli uzyskał zaliczenia z: wykładu i laboratorium. Ocena końcowa jest ustalana na podstawie średniej arytmetycznej z ocen OW i OL.
| W cyklu 2023/2024-Z: student uzyskuje ocenę końcową, jeżeli uzyskał zaliczenia z wykładu i laboratorium; ocena końcowa jest ustalana na podstawie średniej arytmetycznej z ocen OW i OL.
| W cyklu 2024/2025-Z: student uzyskuje ocenę końcową, jeżeli uzyskał zaliczenia z wykładu i laboratorium; ocena końcowa jest ustalana na podstawie średniej arytmetycznej z ocen OW i OL.
|
<b>Wymagania wstępne</b>
W cyklu 2022/2023-Z: student osiągnął efekty uczenia się w zakresie modułów: Programowanie I (IZI.20 – sem. I), Programowanie II (IZI.21 – sem. II), Podstawy interakcji człowiek-komputer (IZI.24 – sem. I) oraz Algorytmy i struktury danych (IZI.25 – sem. II). Wymagań dodatkowych brak.
| W cyklu 2023/2024-Z: student osiągnął efekty uczenia się w zakresie modułów: Programowanie I (IZI.20 – sem. I), Programowanie II (IZI.21 – sem. II), Podstawy interakcji człowiek-komputer (IZI.24 – sem. I) oraz Algorytmy i struktury danych (IZI.25 – sem. II); wymagań dodatkowych brak.
| W cyklu 2024/2025-Z: student osiągnął efekty uczenia się w zakresie modułów: Programowanie I (IZI.20 – sem. I), Programowanie II (IZI.21 – sem. II), Podstawy interakcji człowiek-komputer (IZI.24 – sem. I) oraz Algorytmy i struktury danych (IZI.25 – sem. II); wymagań dodatkowych brak.
|
<b>Literatura podstawowa</b>
- Dewson R.: SQL Server. Wstęp dla programistów, Helion, wyd. IV, Gliwice 2016
- Ben-Gan I.: Podstawy języka T-SQL. Microsoft SQL Server 2016 I Azure SQL Database, APN Promise, Warszawa 2016
<b>Literatura uzupełniająca</b>
- Garcia-Molina H., Ullman J.D., Widom J.: Systemy baz danych. Pełny wykład, WNT, Warszawa 2006
- Campbell L., Majors C.: Inżynieria niezawodnych baz danych. Projektowanie systemów odpornych na błędy, Helion, Gliwice 2018
<b>Inne informacje</b>
Efekty kształcenia
Wiedza
Posiada wiedzę dotyczącą struktury języka zapytań SQL, składni poszczególnych poleceń, klauzul i technik tworzenia większości składników relacyjnych baz danych
Powiązane efekty kierunkowe:
IF1A_W04
Metody weryfikacji:
Kolokwium
Wiedza
Posiada niezbędną wiedzę z zakresu modelowania struktur danych za pomocą wybranych narzędzi informatycznych, ma świadomość istnienia i konieczności stosowania dobrych praktyk w tworzeniu systemów bazodanowych
Powiązane efekty kierunkowe:
IF1A_W09
Metody weryfikacji:
Kolokwium
Umiejętności
Potrafi sprawnie posługiwać się językiem SQL w zakresie uzyskiwania żądanych informacji z systemu bazodanowego. Potrafi w tym celu dobrać i wykorzystać właściwe narzędzie informatyczne.
Powiązane efekty kierunkowe:
IF1A_U03
Metody weryfikacji:
Kolokwium
Umiejętności
Potrafi prawidłowo modelować struktury baz danych, właściwie dobierając i wykorzystując znane metody, techniki i narzędzia informatyczne, uwzględniając przyjęte założenia projektowe.
Powiązane efekty kierunkowe:
IF1A_U24, IF1A_U25
Metody weryfikacji:
Kolokwium
Umiejętności
Ma świadomość i umiejętność właściwego i precyzyjnego dokumentowania tworzonych systemów baz danych oraz zrozumiałego dla innych formułowania zasad ich działania.
Powiązane efekty kierunkowe:
IF1A_U04
Metody weryfikacji:
Ocena aktywności na zajęciach
Kompetencje społeczne
Jest świadomy społecznej roli jaką pełni wykształcony inżynier informatyk, wykazuje odpowiedzialność za tworzone przez siebie dzieła oraz posiada umiejętność przekazywania swojej wiedzy innym w sposób jasny i zrozumiały.
Powiązane efekty kierunkowe:
IF1A_K07
Metody weryfikacji:
Ocena aktywności na zajęciach
Kryteria oceniania
1. Student uzyskuje zaliczenie wykładu na podstawie pozytywnej oceny ze sprawdzianu pisemnego przeprowadzonego na ostatnim wykładzie w semestrze – ocena zaliczająca wykład OW jest ustalana na podstawie oceny ze sprawdzianu. W przypadku zajęć prowadzonych zdalnie, sprawdzian będzie przeprowadzony online na platformie elearning.ubb.edu.pl.
2. Student uzyskuje zaliczenie laboratorium na podstawie pozytywnych ocen z dwóch sprawdzianów pisemnych w semestrze (w przypadku zajęć prowadzonych zdalnie – w formie zadań odsyłanych na platformę elearning.ubb.edu.pl) – ocena zaliczająca laboratorium OL jest ustalana na podstawie średniej arytmetycznej ocen ze sprawdzianów.
3. Zaliczenia poprawkowe (wykład, laboratorium) studenci mogą uzyskać w sesji poprawkowej lub w terminach późniejszych, za zgodą dziekana.
4. Student uzyskuje ocenę końcową OK, jeżeli uzyskał zaliczenia z wykładu i laboratorium. Ocena końcowa OK jest ustalana na podstawie średniej arytmetycznej z ocen OW i OL>.
Literatura
A. Wykaz literatury podstawowej:
1. Ben-Gan I.: Podstawy języka T-SQL. Microsoft SQL Server 2022 I Azure SQL Database, APN Promise, Warszawa 2023
2. Elmsari R., Navathe S.B.: Wprowadzenie do systemów baz danych, wyd. VII, Helion, Gliwice 2019
B. Wykaz literatury uzupełniającej:
1. Ben-Gan I.: Funkcje okna w języku T-SQL dla SQL Server 2019, APN Promise, Warszawa 2019
2. Dewson R.: SQL Server. Wstęp dla programistów, Helion, wyd. IV, Gliwice 2016
3. Garcia-Molina H., Ullman J.D., Widom J.: Systemy baz danych. Pełny wykład, WNT, Warszawa 2006
4. Pelikant A.: MS SQL Server. Zaawansowane metody programowania, wyd. II, Helion, Warszawa 2022