Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

35
Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura

Transcript of Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Page 1: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Una Introduzione alle Basi di Dati

StoriaConcettiModelliStruttura

Page 2: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

In Principio era la scheda… Inizialmente i sistemi informativi su

computer memorizzavano le informazioni su scheda perforata

                                     

                             

Page 3: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

I Limiti di un Sistema Informativo su scheda

Non riutilizzabile Occupa molto spazio per pochi dati E’ macchinoso da trasportare, duplicare,

modificare E’ sequenziale Ha dei limiti sulla dimensione del record Le operazioni di inserimento, modifica,

cancellazione sono manuali

Page 4: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Docente 2

Vengono introdotti i concetti di base Record fisico, campo, record logico

E’ possibile rappresentare archivi correlati

Record fisicoCognome

Campo

StudenteDocente 1

Page 5: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

L’apparizione delle unità a nastro e il Sistema Informativo

Riutilizzabile Occupa poco spazio E’ semplice da trasportare Non ha limiti sulla dimensione del

record fisico E’ sequenziale Le operazioni richiedono due unità

nastro

Page 6: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Le unità a disco Ad accesso diretto Possibile il collegamento

tra più archivi contemporaneamente Riutilizzabile Occupa poco spazio E’ semplice da trasportare Non ha limiti sulla dimensione del

record fisico

Page 7: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Vengono messi a punto gli algoritmi fondamentali Accesso Sequenziale Accesso Diretto Relativo Accesso Sequenziale con Indice Tecniche di Ricerca Ricerca Binaria Indice con B-Tree Tecniche Hash

Page 8: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

La realizzazione di un programma che gestisce archivi

Viene definito il “tipo record” Viene definito l’archivio (nome, supporto

fisico, tipo record, organizzazione fisica) Vengono scritti i sottoprogrammi di

inserimento, modifica, cancellazione, ricerca, stampa nel linguaggio di programmazione prescelto (COBOL, RPG, PL/I )

Page 9: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

I difetti di una gestione tradizionale degli archivi Il modello dei dati è “cablato” nei programmi I controlli sono “cablati” nei programmi I programmi devono cambiare se cambia il modello

logico o fisico dei dati Programmi diversi possono usare tipi record diversi

per lo stesso archivio Ripetitività degli algoritmi I campi possono essere duplicati in più archivi Ridondanza, rischio di incongruenza e inconsistenza Mancanza di controllo degli accessi Difficoltà nell’accesso multiutente ai dati

Page 10: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Base: cos’è Un Data Base è una collezione di dati operativi

memorizzati su un supporto per computer, utilizzato dai programmi applicativi di una particolare azienda (C. Date)

Un Data Base contiene informazioni collegate tra di loro ed informazioni sulle informazioni (meta-informazioni in un Dizionario dei dati) in maniera da superare i difetti della gestione tradizionale degli archivi

Page 11: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Base: I pregi Il modello dei dati è nel Data Base I controlli di integrità sono nel Data Base Il controllo degli accessi è nel Data Base Raramente i programmi cambiano se cambia il modello

logico o fisico dei dati Programmi diversi usano lo stesso modello per lo stesso

archivio I programmi applicativi non contengono gli algoritmi di base

ma usano un linguaggio di interrogazione e manipolazione per accedere ai dati

L’esigenza di duplicare i campi viene ridotta Meno ridondanza, meno rischio di incongruenza e

inconsistenza Supporto nell’accesso multiutente ai dati

Page 12: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Con un Data Base… La ridondanza dei dati può essere ridotta Le inconsistenze possono essere evitate Le informazioni possono essere condivise Gli standard possono essere rinforzati La sicurezza dell’informazione può essere

controllata E’ possibile trovare un punto di incontro tra

esigenze contrastanti La produttività può essere aumentata

Page 13: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Base: I difetti Costa all’utente e alla Software House Richiede maggiori risorse di calcolo Richiede tempi di addestramento Richiede figure professionali specifiche

(Data Base Administrator) Richiede per grossi data base modifiche

organizzative nel centro E.D.P.

Page 14: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Base Management System

Gestione delModello Fisico

Gestione delModello Logico

(Dizionario)

InterpreteDel

Linguaggio

Utente interattivo A Utente interattivo B Programma C

Sottomodellodi A

Area di Lavoro

Sottomodellodi B

Area di Lavoro

Sottomodellodi C

Area di Lavoro

E’ il Sistema Software che gestisce Data BasesNasce come insieme di sottoprogrammiOggi è un Sistema Software complesso

Page 15: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

I Modelli dei dati Rappresentano la struttura delle informazioni Il modello concettuale dei dati rappresenta la

struttura delle informazioni inerente al problema nel mondo reale

Il modello logico dei dati rappresenta la struttura delle informazioni così come sono visibili all’utente di un DBMS

Il modello fisico dei dati rappresenta la struttura delle informazioni così come risiede su memoria di massa

Page 16: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

I Modelli dei dati - Esempi

I Dati

Il modello logicodei dati

Page 17: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Concettuale – Un esempio

Page 18: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Modelli dei Dati e Notazioni Il modello concettuale viene espresso usando la

notazione Entity-Relationship di P. Chen o UML (Uniform Modeling Language)

Il modello logico viene espresso usando la notazione supportata dal DBMS

Il modello fisico viene deciso dal DBMS su suggerimento del programmatore o del Data Base Administrator

Page 19: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Schema dei Dati E’ l’insieme dei modelli dei dati contenuti in un

Data Base

Page 20: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Tipi di Modelli dei Dati Gerarchico Reticolare Relazionale Entità-Relazione Orientato ad Oggetti (Semantico)

Page 21: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Entità-Relazione Usato per descrivere il modello concettuale delle

informazioni Inventato da Peter Chen nel 1976 Ogni cosa è una Entità Ogni Entità ha delle proprietà Le Entità con le stesse proprietà fanno parte

dello stesso Insieme di Entità Tra Entità ci possono essere delle Relazioni Le Relazioni possono essere 1:1, 1:n, n:n

Page 22: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Notazione di Chen

Entità

Proprietà

Relazione

Studenti

Nome

Fax

Page 23: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Dal Problema al Modello Concettuale Ogni nome diventa una entità Ogni aggettivo diventa una proprietà Ogni verbo diventa una relazione Il verbo HA può diventare una proprietà o una

relazioneEsempio: Uno studente ha un nome, un cognome ed un

indirizzo. Ha inoltre un genitore con nome, un cognome ed un indirizzo.

Studenti Genitori

Cognome CognomeNome Indirizzo Nome Indirizzo

Han n

Page 24: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Gerarchico

Page 25: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Gerarchico – Assunzioni di Base

Page 26: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Linguaggio: IMS-DL/I Data Definition Language

Page 27: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Manipulation Language Cerca per chiave (Get Unique) Cerca il prossimo (Get Next) Cerca il prossimo nel padre (Get Next

Within Parent)

Page 28: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Reticolare

Page 29: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Reticolare – Assunzioni di Base

Page 30: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Linguaggio: Cobol Data Definition Language

Page 31: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Data Manipulation Language Cerca in archivio (Find) Cerca owner (Find owner) Cerca member (Find member)

Page 32: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Modello Relazionale

Page 33: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Assunzioni di Base I duplicati non sono permessi L’ordine non è importante I valori sono atomici Le colonne sono omogenee Le righe sono omogenee

Page 34: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Il Linguaggio: SQL Data Manipulation Language

Data Definition Language

Page 35: Una Introduzione alle Basi di Dati Storia Concetti Modelli Struttura.

Problemi Aperti Qualità del Modello e Normalizzazione Multiutenza e Transazione Ottimizzazione e Data Base Administrator Sicurezza e Data Base Administrator La Frattura con il linguaggio ospite I Limiti del Modello Relazionale