Bazy Danych Wprowadzenie

Slides:



Advertisements
Podobne prezentacje
Indeksy w bazie danych Oracle
Advertisements

Modelowanie logiczne (dla relacyjnych SZBD)
Procedury wyzwalane Procedura wyzwalana (ang. trigger) - stanowi kod użytkownika przechowywany wewnątrz bazy i uruchamiany w określonych sytuacjach np.
Relacyjny model danych
SQL – Strukturalny język zapytań
Relacyjny model danych
Systemy do operowania dużymi i trwałymi zbiorami danych
Komponenty bazy danych Baza danych Jest to uporządkowany zbiór powiązanych ze sobą danych charakterystycznych dla pewnej klasy obiektów lub zdarzeń,
Relacyjny Model Danych
SQL-owskie szlaki górskie
POWTÓRZENIE Dane; Baza danych - BD;
POWTÓRZENIE Metodologia : Pojęcia:
Wykład 8 Wojciech Pieprzyca
Wykład 5 Wojciech Pieprzyca
Wprowadzenie do systemów baz danych
Projektowanie fizycznej bazy danych
WYKONYWANIE ZAPYTAŃ Przygotował Lech Banachowski na podstawie: 1.Raghu Ramakrishnan, Johannes Gehrke, Database Management Systems, McGrawHill, 2000 (książka.
Modele baz danych - spojrzenie na poziom fizyczny
Język SQL – ciąg dalszy DML (Data Manipulation Language)
Bazy Danych Wykład 1 S. Kozielski.
Język SQL (Structured Query Language) DDL (Data Definition Language)
Projektowanie struktury logicznej (schematu) relacyjnych baz danych
Teoria relacyjnych baz danych
Bazy Danych II prowadzący: mgr inż. Leszek Siwik
SQL – zapytania posumowanie
DIAGRAMY ER 2 (ENTITY-RELATIONSHIP DIAGRAMS 2) Ćwiczenia 2.
SQL – Structured Query Language (3)
Bazy danych.
dr hab. Ryszard Walkowiak prof. nadzw.
Systemy baz danych Wykład 1
Budowanie tabel i relacji
Informatyka Relacyjne bazy danych.
Andrzej Macioł Bazy danych – model relacyjny – cz. 1 Andrzej Macioł
SQL - Structured Query Language
Rozwiązanie zadań do zaliczenia I0G1S4 // indeks
Wybrane zagadnienia relacyjnych baz danych
Model relacyjny.
Bazy danych 1 Literatura: Paul Benon-Davies – Systemy baz danych
dr Łukasz Murowaniecki T-109
1 Każdy obiekt jest scharakteryzowany poprzez: tożsamość – daje się jednoznacznie wyróżnić; stan; zachowanie. W analizie obiektowej podstawową strukturą
Bazy danych Microsoft access 2007.
SQL – część II.
Projektowanie relacyjnych baz danych – postacie normalne
Projektowanie bazy danych
Łódź 2008 Banki danych WYKŁAD 2 dr Łukasz Murowaniecki T-109.
Temat 1: Strukturalny język zapytań SQL
1 SBD, L.Banachowski Podstawy SQL - języka relacyjnych i obiektowo-relacyjnych baz danych (SQL2, SQL'1999, Oracle) Powtórzenie wyk ł adu 3.
Wykład I Podstawy relacyjnych baz danych Powtórzenie wiadomości
Temat 3: Integralność danych. Integralność danych, określana również mianem spójności danych, jest to funkcja SZBD, która gwarantuje, że dane nie zostaną.
Michał Krawczykowski kl. IIIB
Definiowanie kluczy w tabelach RBD
Treści multimedialne - kodowanie, przetwarzanie, prezentacja Odtwarzanie treści multimedialnych Andrzej Majkowski informatyka +
Autor: Damian Urbańczyk
Projektowanie relacyjnych baz danych – diagramy związków encji
1 SBD, L.Banachowski Oprogramowanie strony serwera cz. 1 Powtórzenie wyk ł adu 6.
Komendy SQL do pracy z danymi
Projektowanie bazy danych z użyciem diagramów UML Obiektowe projektowanie relacyjnej bazy danych Paweł Jarecki.
BAZY DANYCH MS Access.
Wykład 3 Prowadzący: dr Paweł Drozda. Użytkownik bazy danych – osoba lub aplikacja, mająca dostęp do części danych zgromadzonych w bazie Uprawnienia –
Modelowanie model związków encji
BAZY DANYCH Microsoft Access Akademia Górniczo-Hutnicza Wydział Elektrotechniki, Automatyki, Informatyki i Inżynierii Biomedycznej Katedra Automatyki i.
1 SYSTEMY BAZ I HURTOWNI DANYCH Wstęp. 2 Literatura: 1.„Podstawowy wykład z systemów baz danych” – J.Ullman, J.Widom, WNT, „Systemy baz danych.
Temat: Tworzenie bazy danych
Transformacja modelu EER do modelu relacyjnego
SYSTEMY BAZ I HURTOWNI DANYCH
Strukturalny język zapytań SQL - historia
Treści multimedialne - kodowanie, przetwarzanie, prezentacja Odtwarzanie treści multimedialnych Andrzej Majkowski informatyka +
Technologie Informacyjne Bazy danych
Modele baz danych - spojrzenie na poziom fizyczny
Zapis prezentacji:

Bazy Danych Wprowadzenie Wykład 1 Prowadzący: dr Paweł Drozda

Informacje Ogólne Kontakt: pdrozda@matman.uwm.edu.pl wmii.uwm.edu.pl/~pdrozda Słoneczna 54, pokój E 0/5 Zaliczenie przedmiotu: - Projekt podczas ostatnich zajęć dr P. Drozda

Program Wykładu Wprowadzenie Relacyjny model danych Modelowanie baz danych (diagramy związków encji) Zarządzanie uprawnieniami Język baz danych SQL dr P. Drozda

Literatura J. Ullman, J. Widom „Podstawowy wykład z systemów baz danych” http://wazniak.mimuw.edu.pl P. Beynon-Davies „Systemy baz danych” L. Banachowski „Bazy Danych – Tworzenie Aplikacji” Conolly, Begg „Systemy Baz Danych” Date „Wprowadzenie do Systemów Baz Danych” Wykłady Stanford University – www.coursera.org dr P. Drozda

Plan Wykładu Podstawowe pojęcia System zarządzania bazami danych (DBMS) Właściwości baz danych Modele danych dr P. Drozda

Podstawowe pojęcia Baza danych – zbiór informacji opisujący wybrany fragment rzeczywistości. Np. Dla sklepu: dane dotyczące sprzedawanych towarów w sklepie, klientów sklepu, pracowników, zamówień Schemat baz danych – określa w jaka powinna być struktura danych oraz w jaki sposób dane są powiązane System zarządzania bazą danych (DBMS) – zbiór narzędzi pozwalający na dostęp oraz na zarządzanie jedną lub wieloma bazami danych System baz danych – baza danych + DBMS Model danych – zbiór ogólnych zasad posługiwania się danymi dr P. Drozda

System Baz Danych Aplikacja System Bazy danych DBMS Aplikacja Schemat Baza danych dr P. Drozda

System zarządzania bazą danych Zapytania Modyfikacja schematu Aktualizacje Procesor zapytań Moduł zarządzania transakcjami Moduł zarządzania pamięcią Dane Metadane dr P. Drozda

Cechy SZBD Masywny – możliwość przechowywania TBs Trwały – dane nie znikają Bezpieczny – odporny na awarię Wielu użytkowników – kontrola wielodostępu dr P. Drozda

Modele Danych Dla każdego modelu należy określić Definicja danych Operowanie danymi Integralność danych dr P. Drozda

Modele danych Modele historyczne (klasyczne) Relacyjny model danych Sieciowy Hierarchiczny Relacyjny model danych Obiektowy model danych dr P. Drozda

Model Relacyjny

Definicja danych Relacja – dwuwymiarowa tabela, jedyna struktura danych w modelu relacyjnym Każda relacja posiada atrybuty – kolumny. Opisują dane umieszczane w relacji Schemat relacji – nazwa relacji wraz z atrybutami Przykład schematu: Miasto (id, nazwa, id_regionu) Krotki – wiersze relacji zawierające dane. Każdy atrybut ma swój odpowiednik w krotce dr P. Drozda

Cechy relacji jednoznaczna nazwa relacji jednoznaczne nazwy kolumn (atrybutów) relacji ten sam typ wartości w jednej kolumnie porządek kolumn w relacji nieistotny niedozwolone powtórzenia wierszy nieistotny porządek wierszy (krotek) wartości atomowe w polach relacji dr P. Drozda

Przykłady STUDENCI spełnia reguły ZALICZENIA nie spełnia reguł Nr_indeksu Nazwisko Imię Adres 1234 Kowalski Jan Akacjowa 8 2134 Nowak Piotr Dębowa 4 4321 Maliniak Stefan Bukowa 4 3298 Grabowska Janina Brzozowa 1 spełnia reguły ZALICZENIA Id_indeksu Ocena Przedmiot 1234 (1234), (3214) 5 Bazy danych 3211 (3211), (4327) b. dobry nie spełnia reguł dr P. Drozda

Definicja danych – klucze główne każda relacja musi posiadać klucz główny jedna lub więcej kolumn identyfikujących jednoznacznie każdy wiersz tabeli Klucz kandydujący – atrybut lub zbiór atrybutów identyfikujących wiersze tabeli (musi być jednoznaczny i nie zawierać wartości null) Klucz główny wybierany spośród kluczy kandydujących dr P. Drozda

Definicja danych Dziedzina – zbiór wszystkich możliwych wystąpień atrybutu (np. ocena_z_egzaminu wartości od 2 do 5 – dziedzina 2-5) – każdy atrybut posiada dziedzinę Klucz obcy – kolumna bądź kolumny będące kluczem głównym w innej tabeli, sposób łączenia tabel (np. numer studenta w tabeli Studenci i w tabeli Zaliczenia) Wartość null – nieznana informacja (np. brak numeru telefonu) dr P. Drozda

Przykład STUDENCI Klucz główny Klucz główny ZALICZENIA Klucz obcy Nr_indeksu Nazwisko Imię Adres 1234 Kowalski Jan Akacjowa 8 2134 Nowak Piotr Dębowa 4 4321 Maliniak Stefan Bukowa 4 3298 Grabowska Janina Brzozowa 1 Klucz główny Klucz główny ZALICZENIA Id_indeksu Ocena Przedmiot 1234 5 Bazy danych 3211 4 3 Matematyka Klucz obcy dr P. Drozda

Operowanie danymi Algebra relacyjna – zbiór sześciu operatorów do wyszukiwania danych (selekcja, rzut, złączenie, suma, przecięcie, różnica) Operacje dynamiczne na relacjach INSERT – wstawianie DELETE – usuwanie UPDATE – modyfikowanie dr P. Drozda

Selekcja - ograniczenie Wydobywa wszystkie informacje z relacji z interesującymi użytkownika danymi – nie bierze pod uwagę wszystkich krotek Przykład: SQL: SELECT * FROM STUDENCI where imię=‘Jan’; Wynikiem powyższych zapytań jest relacja Nr_indeksu Nazwisko Imię Adres 1234 Kowalski Jan Akacjowa 8 dr P. Drozda

Rzut – projekcja (1) ogranicza liczbę atrybutów Przykład: PRACOWNICY Pracownik Nazwisko Imię Płaca 1 Stefanek Michał 3000 zł 2 Dębek Jarosław 2340 zł 3 Kowalski Jan 4600 zł dr P. Drozda

Rzut (2) Wynik zapytania: SELECT Nazwisko, Płaca from Pracownicy jest następujący: Nazwisko Płaca Stefanek 3000 zł Dębek 2340 zł Kowalski 4600 zł dr P. Drozda

Operowanie danymi Złączenia – oparte na relacyjnym operatorze iloczynu kartezjańskiego Typy złączeń Iloczyn kartezjański Równozłączenie Złączenie naturalne Złączenia zewnętrzne Lewostronne złączenie zewnętrzne Prawostronne złączenie zewnętrzne Obustronne złączenie zewnętrzne dr P. Drozda

Pozostałe operatory stosowane dla zgodnych relacji - ta sama liczba argumentów w relacjach, ta sama dziedzina dla odpowiadających argumentów analogicznie do algebry zbiorów dr P. Drozda

Pozostałe operatory Przykład PRACOWNICY KIEROWNICY Nr_prac Nazwisko Imię 1 Golał Jan 2 Maser Paweł 3 Jawosz Magda 4 Ferel Michał Nr_prac Nazwisko Imię 1 Golał Jan 6 Resko Regina 7 Janik Tadeusz 9 Rewak Piotr dr P. Drozda

Pozostałe operatory Przecięcie Suma Nr_prac Nazwisko Imię 1 Golał Jan 2 Maser Paweł 3 Jawosz Magda 4 Ferel Michał 6 Resko Regina 7 Rewak Piotr 9 Janik Tadeusz Nr_prac Nazwisko Imię 1 Golał Jan dr P. Drozda

Pozostałe operatory Różnica A-B Różnica A-B Nr_prac Nazwisko Imię 2 Maser Paweł 3 Jawosz Magda 4 Ferel Michał Nr_prac Nazwisko Imię 6 Resko Regina 7 Rewak Piotr 9 Janik Tadeusz dr P. Drozda

Języki zapytań składanie operatorów w celu wydobycia informacji z bazy danych Przykład – znaleźć wszystkie przedmioty prowadzone przez Janika PRACOWNICY PRZEDMIOTY Nr_prac Nazwisko Imię 1 Golał Jan 6 Resko Paweł 3 Janik Tadeusz 4 Ferel Michał IdPrzed Przedmiot Prowadzący 2 Bazy danych null 5 Filozofia 4 6 Analiza matematyczna 3 Statystyka dr P. Drozda

Języki zapytań SQL select Przedmiot from PRACOWNICY inner join PRZEDMIOTY on PRACOWNICY.Nr_prac = PRZEDMIOTY.Prowadzacy where Nazwisko=‘Janik’; dr P. Drozda

Operacje dynamiczne INSERT INTO tabela VALUES (wart1, wart2, …) – wstawia do tabeli wartości wart1, wart2, … Przykład INSERT INTO PRACOWNICY VALUES (10, ‘Banach’, ‘Jacek’) spowoduje dodanie wiersza do relacji PRACOWNICY DELETE FROM tabela WHERE warunek – usuwa z tabeli krotki określone w warunku DELETE FROM PRZEDMIOTY WHERE Prowadzący = 3 – usunie krotki dotyczące analizy matematycznej i statystyki dr P. Drozda

Operacje dynamiczne UPDATE tabela SET nazwaKolumny = wartosc WHERE warunek – zmienia w krotkach określonych w warunku kolumnę nazwaKolumny na podaną wartość Przykład UPDATE PRZEDMIOTY SET prowadzący=1 WHERE prowadzący=3– zmienia prowadzącego przedmiotów analiza matematyczna i statystyka dr P. Drozda

Integralność danych Integralność danych zapewnia dokładne odbicie rzeczywistości w bazie danych W modelu relacyjnym istnieją dwa rodzaje integralności wewnętrznej integralność encji integralność referencyjna dr P. Drozda

Integralność encji Dotyczy kluczy głównych PRACOWNICY Każda relacja musi mieć klucz główny Klucz główny musi być jednoznaczny i nie może zawierać wartości null (co skutkuje jednoznacznością krotek w relacji) Przykład kluczem głównym w tej relacji może być Nr_prac, nazwisko lub imię PRACOWNICY Nr_prac Nazwisko Imię 1 Golał Jan 2 Resko Paweł 3 Janik Tadeusz 4 Ferel Michał dr P. Drozda

Integralność referencyjna Dotyczy kluczy obcych dwie możliwości (w zależności od konkretnej bazy danych) - Wartość klucza obcego musi odwoływać się do wartości klucza głównego w tabeli w bazie danych - Wartość klucza obcego może być null - Wymuszenie istnienia odniesienia każdego wiersza – parametr not null dr P. Drozda

Integralność referencyjna Przykład Nr_prac Nazwisko Imię 1 Golał Jan 6 Resko Paweł 3 Janik Tadeusz 4 Ferel Michał IdPrzed Przedmiot Prowadzący 2 Bazy danych null 5 Filozofia 4 6 Analiza matematyczna 3 Statystyka Integralność referencyjna zachowana, jeśli są dopuszczane wartości null klucza obcego (klucze obce mogą należeć do zbioru {1,3,4,6}) dr P. Drozda

Zachowanie integralności referencyjnej Określenie więzów propagacji – określają co ma się stać z tabelą przy modyfikacji powiązanej tabeli Ograniczone usuwanie – usunięcie krotki z kluczem głównym możliwe w momencie, gdy klucz główny nie ma wystąpień jako klucz obcy Dla poprzedniego przykładu – z tabeli pracownicy można usunąć pracowników o numerach 1 i 6. Pozostali mogą zostać usunięci dopiero w momencie gdy zostaną usunięte odpowiednie krotki w powiązanej tabeli dr P. Drozda

Zachowanie integralności referencyjnej Kaskadowe usuwanie Przy usunięciu wiersza z kluczem głównym zostają usunięte wszystkie wiersze z tym kluczem z relacji powiązanej Jeśli usuniemy z tabeli PRACOWNICY pracownika o numerze 3 – zostaną usunięte Przedmioty o numerach 6 i 3 z tabeli PRZEDMIOTY Wstaw null – przy usunięciu krotki z kluczem głównym zostają wstawione wartości null zamiast klucza obcego Wstaw default – przy usuwaniu wstawia wartość domyślną dr P. Drozda

Integralność dodatkowa Definiowana przez użytkownika – specyficzna dla każdej bazy danych Przykład Możemy wymusić, że każdy pracownik musi prowadzić jakieś zajęcia dr P. Drozda