Basi di Dati Complementi. 2. Tecnologie per DBMS -2.4 Introduzione alle Transazioni e Buffer Manager
|
|
- Monica Vaccaro
- 5 anni fa
- Visualizzazioni
Transcript
1 Basi di Dati Complementi 2. Tecnologie per DBMS -2.4 Introduzione alle Transazioni e Buffer Manager Andrea Maurino Parte del materiale è stato fornito dal prof. Batini Fonti Libro Architetture e linee di evoluzione 2/ed Capitolo 2.1 Capitolo Libro Sistemi di basi di dati (complementi) Elmasri Navathe Capitolo 1.1 1
2 Definizione di transazione Insieme di istruzioni di lettura e scrittura sulla base di dati Eventualmente inserite in un liguaggio programmativo L insieme delle istruzioni gode di alcune proprietà che garantiscono la corretta esecuzione in un ambiente concorrente e non affidabile Definizione di transazione Transazione: parte di programma caratterizzata da un inizio (begintransaction, start transaction in SQL), una fine (endtransaction, non esplicitata in SQL) e al cui interno deve essere eseguito una e una sola volta uno dei seguenti comandi commit work per terminare correttamente rollback work per abortire la transazione Un sistema transazionale (OLTP) e in grado di definire ed eseguire transazioni per conto di un certo numero di applicazioni concorrenti 2
3 Differenza fra applicazione e transazione begin T1 AZIONI TRANSAZIONE T1 PROGRAMMA APPLICATIVO end T1 begin T2 AZIONI TRANSAZIONE T2 end T2 Una transazione start transaction; set Saldo = Saldo + 10 where NumConto = 12202; set Saldo = Saldo 10 where NumConto = 42177; commit work; 3
4 Una transazione con varie decisioni start transaction; set Saldo = Saldo + 10 where NumConto = 12202; set Saldo = Saldo 10 where NumConto = 42177; select Saldo into A from ContoCorrente where NumConto = 42177; if (A>=0) then commit work else rollback work; Transazioni in JDBC Scelta della modalità delle transazioni: un metodo definito nell'interfaccia Connection: setautocommit(boolean autocommit) con.setautocommit(true) (default) "autocommit": ogni operazione è una transazione con.setautocommit(false) gestione delle transazioni da programma con.commit() con.rollback() non c'èstart transaction 4
5 Sintassi SQL per specificare le transazioni Le istruzioni commit work e rollback work possono comparire più volte all interno del programma Durante l esecuzione della transazione è necessario che esattamente una istanza delle due istruzioni sia eseguita Commit work se la transazione è avvenuta correttamente Rollback (abort) e la transazione non deve essere completata Il sistema deve ripristinare lo STATO precedente Approccio binario NON SONO AMMESSE SITUAZIONI INTERMEDIE Il concetto di transazione Una unità di elaborazione che gode delle proprietà "ACID" Atomicità Consistenza Isolamento Durata (persistenza) 5
6 Atomicità Una transazione è una unità atomica di elaborazione Non può lasciare la base di dati in uno stato intermedio un guasto o un errore prima del commit debbono causare l'annullamento (UNDO) delle operazioni svolte un guasto o errore dopo il commit non deve avere conseguenze; se necessario vanno ripetute (REDO) le operazioni Esito Commit = caso "normale" e più frequente (99%?) Abort (o rollback) richiesto dall'applicazione = suicidio requested dal sistema (violazione dei vincoli, concorrenza, incertezza in caso di fallimento) = omicidio Esempio Data la transazione begin transaction; set Saldo = Saldo + 10 where NumConto = 12202; If (saldo<=0) Then rollback work set Saldo = Saldo 10 where NumConto = 42177; select Saldo into A from ContoCorrente where NumConto = 42177; if (A>=0) then commit work else rollback work; end transaction (0) (1) (2) 6
7 Esempio Viene eseguita l istruzione (1) il tentativo di eseguire (2) fallisce Il sistema DEVE annullare l operazione precedete per preservare la proprietà di atomicità Il DBMS riporta il DB allo stato precedente l inizio della transazione Rollback work imposto dal sistema begin transaction; set Saldo = Saldo + 10 where NumConto = 12202; If (saldo<=0) Then rollback work set Saldo = Saldo 10 where NumConto = 42177; select Saldo into A from ContoCorrente where NumConto = 42177; if (A>=0) then commit work else rollback work; end transaction (0) (1) (2) Esempio Viene eseguita l istruzione (1) La condizione è vera per cui l applicazione chiede il roolback della transazione Il DBMS riporta il DB allo stato precedente l inizio della transazione Rollback work imposto dall applicazione begin transaction; set Saldo = Saldo + 10 where NumConto = 12202; If (saldo<=0) Then rollback work set Saldo = Saldo 10 where NumConto = 42177; select Saldo into A from ContoCorrente where NumConto = 42177; if (A>=0) then commit work else rollback work; end transaction (0) (1) (2) 7
8 Consistenza La transazione rispetta i vincoli di integrità Conseguenza: se lo stato iniziale e' corretto anche lo stato finale e' corretto Durante l esecuzione ci possono essere delle violazioni, ma non devono restare alla fine della transazioni Nel caso rollback work Isolamento/Concorrenza La transazione non risente degli effetti delle altre transazioni concorrenti l'esecuzione concorrente di una collezione di transazioni deve produrre un risultato che si potrebbe ottenere con una esecuzione sequenziale Conseguenza: una transazione non espone i suoi stati intermedi Si evita l' "effetto domino 8
9 Concorrenza - 1 Il throughput di un sistema e il numero di transazioni per secondo (tps) accettate dal sistema a regime In un sistema che non prevede esecuzione concorrente, il throughput e al massimo pari al tempo di esecuzione di una singola transazione Puo essere dell ordine dei secondi per una normale applicazione OLTP In un DBMS, si vuole ottenere un throughput dell ordine di tps Questo impone un alto grado di concorrenza tra le transazioni in esecuzione Es Se una transazione impiega mediamente 0.1 secondi ad eseguire, ad un throughput di 100tps corrispondono mediamente 10 transazioni in esecuzione concorrente Esempi tipici: applicazioni bancarie, di prenotazione voli Concorrenza - esempio Void chooseseat() { /* codice C che verifica la disponibilita di posti su un volo e prenota un posto */ (1) EXEC SQL SELECT occupied INTO :occ FROM flights WHERE fltnum = :flight AND fltdate = :date AND fltseat = :seat; (2) if (!occ) { EXEC SQL UPDATE Flights SET occupied = TRUE WHERE fltnum = :flight AND fltdate = :date AND fltseat = :seat; /* notifica posto prenotato */ } else /* notifica volo completo */ } 9
10 Concorrenza - 2 Supponiamo che la funzione chooseseat() venga eseguita simultaneamente da due o piu applicazioni (es due agenzie viaggi), che cercano di prenotare lo stesso posto sullo stesso volo E possibile un evoluzione temporale come la seguente: Appl. 1 Esegue (1), trova posto Esegue (2), alloca il posto Appl. 2 Esegue (1), trova posto Esegue (2), alloca il posto tempo A questo punto, abbiamo una doppia prenotazione (LOST UPDATE) Il DBMS transazionale gestisce questo problema garantendo la proprieta di isolamento Concorrenza -3 Considerando la transazione vista prima Supponiamo che l app1 termini l esecuzione della prenotazione, ma non termina con successo la transazione Un altra applicazione accede alla base di dati delle prenotazioni prima che il DBMS riporti lo stato del DB prima dell esecuzione della app1 Risultato il posto che è nella realtà libero per il sistema è occupato (dirty read) Una transazione deve leggere due volte lo stesso dato. Tra una lettura e l altra una seconda transazione modifica i valori del dato. La prima transazione leggere due dati diversi Letture non ripetibili 10
11 Proprieta di Isolamento delle transazioni Scriviamo la funzione precedente come una transazione: Void chooseseat() { Begin transaction (1) EXEC SQL SELECT occupied INTO :occ FROM flights WHERE fltnum = :flight AND fltdate = :date AND fltseat = :seat; (2) if (!occ) { EXEC SQL UPDATE Flights SET occupied = TRUE WHERE fltnum = :flight AND fltdate = :date AND fltseat = :seat; /* notifica posto prenotato */ } else { /* notifica volo completo */ } commit work; } La proprieta di isolamento di una transazione garantisce che essa e eseguita come se non ci fosse concorrenza Durabilità (Persistenza) Gli effetti di una transazione andata in commit non vanno perduti ("durano per sempre"), anche in presenza di guasti Commit significa impegno Come vedremo questo implica la presenza di un componente nel DBMS che garantisca l affidabilità (recovery manager) 11
12 Transazioni e moduli di DBMS Atomicità e durabilità Gestore dell'affidabilità (Reliability manager) Isolamento: Gestore della concorrenza Consistenza: Gestore dell'integrità a tempo di esecuzione (con il supporto del compilatore del DDL) Gestore degli accessi e delle interrogazioni Gestore delle transazioni Gestore di Interrogazioni e aggiornamenti Gestore delle transazioni Gestore dei metodi d accesso Gestore del buffer Gestore della memoria secondaria Gestore della concorrenza Isolamento Consistenza Gestore della affidabilità Atomicità Persistenza Memoria secondaria 12
13 Buffer management Buffer: area di memoria centrale, gestita dal DBMS (preallocata) e condivisa fra le transazioni organizzato in pagine di dimensioni pari o multiple di quelle dei blocchi di memoria secondaria (1KB-100KB) è importantissimo per via della grande differenza di tempo di accesso fra memoria centrale e memoria secondaria Utilizzata anche dal sistema Log vedi piùavanti Scopo della gestione del buffer Ridurre il numero di accessi alla memoria secondaria In caso di lettura, se la pagina è già presente nel buffer, non è necessario accedere alla memoria secondaria In caso di scrittura, il gestore del buffer può decidere di differire la scrittura fisica (ammesso che ciò sia compatibile con la gestione dell affidabilità vedremo più avanti) La gestione dei buffer e la differenza di costi fra memoria principale e secondaria possono suggerire algoritmi innovativi. Il buffer è gestito con gli stessi criteri di una cache Operazioni primitive di gestion dei blocchi in cache Principio di località dei dati e strategie di sostituzione dei blocchi Regola empirica: 80% delle applicazioni accede al 20% dei dati Valutazione dell hit ratio come per i SO (e le memorie cache dei calcolatori) Per garantire Atomicità e Persistenza sono necessarie strategie di recovery in caso di guasto 13
14 Dati gestiti dal buffer manager Il buffer Un direttorio che per ogni pagina mantiene (ad esempio) il file fisico e il numero del blocco due variabili di stato: un contatore che indica quanti programmi utilizzano la pagina un bit che indica se la pagina è sporca, cioè se è stata modificata Funzioni del buffer manager Intuitivamente: riceve richieste di lettura e scrittura (di pagine) le esegue accedendo alla memoria secondaria solo quando indispensabile e utilizzando invece il buffer quando possibile esegue le primitive fix, unfix, setdirty, force. 14
15 Interfaccia offerta dal buffer manager fix: richiesta di una pagina; richiede una lettura solo se la pagina non è nel buffer (incrementa il contatore associato alla pagina) setdirty: comunica al buffer manager che la pagina è stata modificata unfix: indica che la transazione ha concluso l'utilizzo della pagina (decrementa il contatore associato alla pagina) use: accede alla pagina caricata force: trasferisce in modo sincrono una paginain memoriasecondaria (su richiesta del gestore dell'affidabilità, non del gestore degli accessi) flush: trasferisce in modo sincrono una paginain memoriasecondaria (su decisione del buffer manager) Esecuzione della fix Cerca la pagina nel buffer; se c'è, restituisce l'indirizzo altrimenti, cerca una pagina libera nel buffer (contatore a zero); se la trova, restituisce l'indirizzo altrimenti, due alternative steal : selezione di una "vittima", pagina occupata del buffer; I dati della vittima sono scritti in memoria secondaria; viene letta la pagina di interesse dalla memoria secondaria e si restituisce l'indirizzo no-steal : l'operazione viene posta in attesa 15
16 Commenti Il buffer manager richiede scritture in due contesti diversi: in modosincrono quando è richiesto esplicitamente con una force (ad esempio dopo una commit) in modoasincrono quando lo ritiene opportuno (o necessario) con una flush; in particolare, può decidere di anticipare o posticipare scritture per coordinarle e/o sfruttare la disponibilità dei dispositivi È più efficace del modo sincrono 16
Intoduzione alle transazioni e alle proprieta ACID delle transazioni
Basi di Dati Complementi Parte 2: Tecnologie per MS Parte 2.4: Introduzione alle transazioni e Intoduzione alle transazioni e alle proprieta ACID delle transazioni @ Carlo Batini 2006 1 @ Carlo Batini
DettagliLe transazioni. Update CC set saldo = saldo + 25 where ccnum = Update CC set saldo = saldo 25 where ccnum = 26488
Le transazioni Basi di dati: Architetture e linee di evoluzione - Seconda edizione Capitolo 2 (paragrafo 2.1) Appunti dalle lezioni Transazione ContiCorrenti(ccnum,saldo) Update CC set saldo = saldo +
DettagliGestione delle transazioni. Basi di dati. Elena Baralis 2007 Politecnico di Torino 1 D B M G D B M G 2. Linguaggio SQL: costrutti avanzati
Linguaggio SQL: costrutti avanzati D B M G Introduzione Transazioni in SQL Proprietà delle transazioni D B M G 2 2007 Politecnico di Torino 1 D B M G Esempio applicativo Operazioni bancarie operazione
DettagliIl linguaggio SQL: transazioni
Il linguaggio SQL: transazioni Sistemi Informativi T Versione elettronica: 04.8.SQL.transazioni.pdf Cos è una transazione? Una transazione è un unità logica di elaborazione che corrisponde a una serie
DettagliSistemi mono o multiutente. Un criterio per classificare un sistema di basi di dati è il numero degli utenti che possono fruirne simultaneamente.
TRANSAZIONI Introduzione alla gestione delle transazioni 2 Sistemi mono o multiutente Un criterio per classificare un sistema di basi di dati è il numero degli utenti che possono fruirne simultaneamente.
DettagliSistemi informativi e basi di dati. Il modello relazionale. SQL come DCL Utilizzo di un DBMS Reale. Forme normali. Basi di dati direzionali
Le transazioni Appunti dalle lezioni SQL come DDL Sistemi informativi e basi di dati La Progettazione Concettuale SQL come DML Il modello relazionale La Progettazione Logica SQL come DCL Utilizzo di un
DettagliSQL Transazioni. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni
SQL Transazioni Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Transazioni Le Transazioni sono unità elementari di lavoro sulla base di dati di cui si vogliono garantire proprietà di
DettagliL evoluzione della specie
DBMS Data Base Management System Dai dati grezzi ad informazioni strutturate 1 L evoluzione della specie Strumenti di Business Intelligence Data Warehouse Data Mining Data Base Management System (DBMS)
DettagliOrganizzazione fisica dei dati: Introduzione
Organizzazione fisica dei dati: Introduzione Basi di dati: Architetture e linee di evoluzione - Seconda edizione Capitolo 1 Appunti dalle lezioni Memoria principale e secondaria I programmi possono fare
DettagliBasi di Dati e Sistemi Informativi. Organizzazione fisica dei dati. Corso di Laurea in Ing. Informatica Ing. Gestionale Magistrale
Giuseppe Loseto Corso di Laurea in Ing. Informatica Ing. Gestionale Magistrale Struttura DBMS Gestore delle interrogazioni Decide le strategie di accesso ai dati per rispondere alle interrogazioni Gestore
DettagliTecnologia di un Database Server (centralizzato) Introduzione generale
Introduzione Basi di Dati / Complementi di Basi di Dati 1 Tecnologia di un Database Server (centralizzato) Introduzione generale Angelo Montanari Dipartimento di Matematica e Informatica Università di
DettagliGESTIONE DELLE TRANSAZIONI
GESTIONE DELLE TRANSAZIONI Transazioni! L esecuzione concorrente dei programmi utente è essenziale per le buone prestazioni del DBMS! Poiché gli accessi al disco sono frequenti e relativamente lenti, è
DettagliCorso di. Basi di Dati I. 10. Esercitazioni in SQL: Complementi
Corso di Basi di Dati 10. Esercitazioni in SQL: Complementi A.A. 2016 2017 Funzioni condizionali Vediamo qualche altro comando utile di SQL. Il comando coalesce ammette come argomento una sequenza di espressioni
DettagliCorso di. Basi di Dati I. 10. Esercitazioni in SQL: Complementi
Corso di Basi di Dati 10. Esercitazioni in SQL: Complementi A.A. 2016 2017 Funzioni condizionali Vediamo qualche altro comando utile di SQL. Il comando coalesce ammette come argomento una sequenza di espressioni
DettagliARCHITETTURA DI UN B.D.M.S. Parte III Il Controllo di Affidabilità
ARCHITETTURA DI UN B.D.M.S. Parte III Il Controllo di Affidabilità Michele de Nittis Generalità Il controllo di affidabilità (CA) è quel servizio che provvede a garantire le proprietà di atomicità e persistenza
DettagliMeccanismi per la Gestione efficiente di transazioni in un DBMS
Meccanismi per la Gestione efficiente di transazioni in un DBMS Transazioni Una Transazione è una sequenza di azioni di lettura e scrittura della base di dati e di elaborazioni di dati in memoria temporanea,
DettagliTecnologia delle Basi di Dati
Basi di Dati Prof. Alfredo Cuzzocrea Università degli Studi di Trieste Tecnologia delle Basi di Dati Credits to: Dr. A. Poggi UniRoma1 Transazioni Una transazione è una unità elementare di lavoro svolta
DettagliBasi di Dati e Sistemi Informativi. Architetture Distribuite per Basi di Dati. Corso di Laurea in Ing. Informatica Ing. Gestionale Magistrale
Architetture Distribuite per Basi di Dati Giuseppe Loseto Corso di Laurea in Ing. Informatica Ing. Gestionale Magistrale Architetture Distribuite Parallelismo: usato per ottimizzare le prestazioni di componenti/sistemi
DettagliTransazioni. Transazioni. Stati di una transazione. Transazioni
Transazioni Antonella Poggi Domenico Lembo Dipartimento di informatica e Sistemistica SAPIENZA Università di Roma Progetto di Applicazioni Software Anno accademico 2009-2010 Transazioni Una transazione
DettagliTransazioni. Antonella Poggi. Dipartimento di informatica e Sistemistica Università di Roma La Sapienza
Transazioni Antonella Poggi Dipartimento di informatica e Sistemistica Università di Roma La Sapienza Progetto di Applicazioni Software Anno accademico 2008-2009 Questi lucidi sono stati prodotti sulla
DettagliEsempio di sistema informativo
Corso di Laurea in Ingegneria Informatica Fondamenti di Informatica II Modulo Basi di dati a.a. 2013-2014 Docente: Gigliola Vaglini Docente laboratorio: Francesco Pistolesi Esempio di sistema informativo
DettagliSistemi di Elaborazione dell Informazione
Sistemi di Elaborazione dell Informazione Parte Seconda I Dati Sistemi Operativi Funzioni Principali Gestione di Processi Creazione, sospensione, terminazione, comunicazione sincronizzazione, gestione
DettagliSistemi Informativi: transazioni
Sistemi Informativi: transazioni 1 Progettazione delle transazioni Transazione Unita logica di lavoro Transizione tra due stati consistenti del DB Atomica: tutti i risultati registrati assieme oppure nessuno
DettagliFunzioni del DBMS. Transazioni. Transazioni: esempio. Parte VII. Gestione delle transazioni
Funzioni del DBMS Parte VII Gestione delle transazioni Basi di dati - prof. Silvio Salza - a.a. 2014-2015 VII - 1 Gestione dei dati: cura la memorizzazione permanente dei dati ed il loro accessso Gestione
DettagliParte VII. Gestione delle transazioni
Parte VII Gestione delle transazioni Basi di dati - prof. Silvio Salza - a.a. 2014-2015 VII - 1 Funzioni del DBMS Gestione dei dati: cura la memorizzazione permanente dei dati ed il loro accessso Gestione
DettagliParte VII Gestione delle transazioni
Parte VII Gestione delle transazioni Basi di dati - prof. Silvio Salza - a.a. 2014-2015 VII - 1 Funzioni del DBMS Gestione dei dati: cura la memorizzazione permanente dei dati ed il loro accessso Gestione
DettagliCorso di Laurea in Ingegneria Informatica Fondamenti di Informatica II Modulo Basi di dati a.a
Corso di Laurea in Ingegneria Informatica Fondamenti di Informatica II Modulo Basi di dati a.a. 2012-2013 2013 Docente: Gigliola Vaglini Docenti laboratorio: Francesco Pistolesi,, Antonio Virdis Lezione
DettagliParte 3 Gestione del buffer e gestione del recovery
Gestione dei dati Parte 3 Gestione del buffer e gestione del recovery Maurizio Lenzerini, Riccardo Rosati Facoltà di Ingegneria Sapienza Università di Roma Anno Accademico 2012/2013 http://www.dis.uniroma1.it/~rosati/gd/
DettagliSQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)
1 SQL Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS) a.a. 2015/2016 http://www.di.uniba.it/~lisi/courses/basi-dati/bd2015-16.htm dott.ssa Francesca A. Lisi francesca.lisi@uniba.it
DettagliControllo di concorrenza. concorrenza 1
Controllo di concorrenza concorrenza 1 I vantaggi della concorrenza sul server (1 cpu, 1 disco, 1 sistema di trasmissione) è possibile il parallelismo tra: elaborazione :cpu (c) operazioni di I/O: disco
DettagliEsempio di sistema informativo
Corso di Laurea in Ingegneria Informatica Algoritmi e basi di dati Modulo Basi di dati a.a. 2009-2010 2010 Docente: Gigliola Vaglini Docente laboratorio: Luca Martini Esempio di sistema informativo GESTIONE
DettagliIl linguaggio SQL: transazioni
Il linguaggio SQL: transazioni Sistemi Informativi T Versione elettronica: 04.8.SQL.transazioni.pdf Cos è una transazione? Una transazione è un unità logica di elaborazione che corrisponde a una serie
DettagliEsecuzione concorrente di transazioni
Esecuzione concorrente di transazioni A L B E R T O B E L U S S I P A R T E I I A N N O A C C A D E M I C O 2 0 1 0-2 0 1 1 Tecniche applicate nei DBMS Le tecniche per il controllo della concorrenza che
DettagliUnità D3. Sicurezza nelle basi di dati. Sicurezza e concorrenza nelle basi di dati. Controllo accesso. Protezione e integrità dati
Sicurezza nelle basi di dati Unità D3 Sicurezza e concorrenza nelle basi di dati Una base di dati è sicura quando soddisfa i seguenti parametri: regola l accesso ai dati protetti; evita la modifica o la
DettagliOrganizzazione fisica e gestione delle interrogazioni
Organizzazione fisica e gestione delle interrogazioni Atzeni, Ceri, Paraboschi, Torlone Basi di dati Architetture e linee di evoluzione McGraw-Hill Italia Capitolo 1 Memoria principale e secondaria I programmi
DettagliLinguaggio SQL: costrutti avanzati
Linguaggio SQL: costrutti avanzati Gestione delle transazioni Introduzione Transazioni in SQL Proprietà delle transazioni 2 Pag. 1 1 Gestione delle transazioni Esempio applicativo Operazioni bancarie operazione
DettagliSerializable Snapshot Isolation (SSI) in PostgreSQL 9.1
Serializable Snapshot Isolation (SSI) in PostgreSQL 9.1 Marco Nenciarini Italian PostgreSQL Users Group www.itpug.org www.postgresql.org Chi sono? DBA, sviluppatore e sysadmin presso 2ndQuadrant Database
DettagliLa durability. I dati modificati da una transazione che ha fatto il commit non devono mai essere persi. La durability consente di reagire a:
La durability Basi di dati: Architetture e linee di evoluzione - Seconda edizione Capitolo 2 Appunti dalle lezioni Durability (Persistenza) I dati modificati da una transazione che ha fatto il commit non
DettagliTecnologia di un DBMS
Tecnologia di un DBMS Atzeni, Ceri, Paraboschi, Torlone Basi di Dati: Architetture e Linee di Evouzione McGraw-Hill Italia Capitolo 2 Introduzione Update CC set saldo = saldo 25 where ccnum = 26488 Update
DettagliGestione della Concorrenza
Corso di Complementi di Basi di Dati Gestione della Concorrenza Angelo Montanari 1 Anomalie delle transazioni concorrenti -1 Perdita di aggiornamento Lettura sporca Aggiornamento fantasma 2 2 Anomalie
DettagliComponenti di un DBMS
Componenti di un DBMS Come fa un DBMS a garantire le proprietà ACIDe di una transazione? Vediamo i componenti principali dal più interno a quello di più alto livello: Controllore di Concorrenza Gestore
DettagliIntroduzione D B M G
Introduzione D B M G Introduzione alle basi di dati Gestione delle informazioni Base di dati Modello dei dati Indipendenza dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS D B M G 2 Gestione delle
DettagliElena Baralis 2007 Politecnico di Torino 1
Introduzione Sistemi informativi 2 Introduzione Base di dati Modello dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS 4 6 2007 Politecnico di Torino 1 7 8 9 10 Sistema informatico Nei sistemi informatici,
DettagliCorso integrato di Sistemi di Elaborazione. Modulo I. Prof. Crescenzio Gallo.
Corso integrato di Sistemi di Elaborazione Modulo I Prof. Crescenzio Gallo crescenzio.gallo@unifg.it Basi di dati: introduzione 2 Introduzione Gestione delle informazioni Basi di dati / DBMS Modello dei
DettagliCap. 1-I 1 I sistemi informatici
Libro di testo A. Chianese,V. Moscato, A. Picariello, L. Sansone Basi di dati per la gestione dell informazione McGraw-Hill, 2007 Informazioni sul corso http://www.docenti.unina.it/lucio.sansone Ricevimento
DettagliOrganizzazione fisica dei dati
Organizzazione fisica dei dati Appunti dalle lezioni SQL come DDL Sistemi informativi e basi di dati La Progettazione Concettuale SQL come DML Il modello relazionale La Progettazione Logica SQL come DCL
DettagliPag. 1. Gestione delle transazioni. Linguaggio SQL: costrutti avanzati. Esempio applicativo. Gestione delle transazioni. Prelievo. Esempio applicativo
Gestione delle transazioni Introduzione Transazioni in SQL Linguaggio SQL: costrutti avanzati 2 applicativo Operazioni bancarie operazione di prelievo dal proprio conto corrente mediante bancomat Gestione
DettagliIl linguaggio SQL: transazioni
Il linguaggio SQL: transazioni Sistemi Informativi T Versione elettronica: 04.8.SQL.transazioni.pdf Esecuzione seriale di transazioni Un DBMS, dovendo supportare l esecuzione di diverse transazioni che
DettagliElena Baralis 2007 Politecnico di Torino 1
Introduzione Basi di dati DB M BG2 Introduzione Base di dati Modello dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS DB M BG4 D B M G6 2007 Politecnico di Torino 1 D B M G7 D B M G8 D B M G9 D B
DettagliTecnologie Web T Gestione delle Transazioni e Livelli di Isolamento
Tecnologie Web T Gestione delle Transazioni e Livelli di Isolamento Home Page del corso: http://www-db.disi.unibo.it/courses/tw/ Versione elettronica: 4.03.Transazioni.pdf Versione elettronica: 4.03. Transazioni-2p.pdf
DettagliCognome Nome Matricola Ordin.
Basi di dati II, primo modulo Tecnologia delle basi di dati Prova parziale 27 marzo 2009 Compito A Scrivere il nome su questo foglio e su quello protocollo. Rispondere su questo foglio, eventualmente con
DettagliRecovery manager Gestore della affidabilità
Riferimenti Basi di Dati Complementi Parte 2: Tecnologie per DBMS Parte 2.5: Recovery Manager Trasparenze parte Recovery manager Basi di Dati Atzeni et al. - Capitolo 2.1, 2.2 Anche: Garcia Molina, Ullman,
DettagliParte IX Basi di dati distribuite e parallele
Parte IX Basi di dati distribuite e parallele Basi di dati - prof. Silvio Salza - a.a. 2014-2015 IX - 1 Architetture distribuite e parallele Diverse soluzioni architetturali (sia hardware che software),
DettagliCapitolo 20. I Sistemi Informativi
Capitolo 20 I Sistemi Informativi Il Sistema Informativo È il sistema che gestisce le informazioni che, attualmente, vengono codificate e rappresentate sotto forma di dati, memorizzati su appositi supporti,
DettagliGestione delle informazioni Base di dati Modello dei dati Indipendenza dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS
2007 Politecnico di Torino 1 Basi di dati DB M B G Gestione delle informazioni Base di dati Modello dei dati Indipendenza dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS DB M B G 2 2007 Politecnico
DettagliElena Baralis 2007 Politecnico di Torino 1
2007 Politecnico di Torino 1 Basi di dati Gestione delle informazioni Base di dati Modello dei dati Accesso ai dati Vantaggi e svantaggi dei DBMS DB M BG2 Gestione delle informazioni Le informazioni sono
DettagliFile e indici. Tecnologia delle BD: perché studiarla? Le basi di dati sono grandi e persistenti. DataBase Management System DBMS
1 Tecnologia delle BD: perché studiarla? File e indici I DBMS offrono i loro servizi in modo "trasparente": per questo abbiamo potuto finora ignorare molti aspetti realizzativi abbiamo considerato il DBMS
DettagliBasi di dati Architetture e linee di evoluzione. Gestione delle transazioni. Sistema di Gestione di Basi di Dati. Le Basi di Dati sono GRANDI
Sistema di Gestione di Basi di Dati Basi di dati Architetture e linee di evoluzione Capitolo 2 Gestione delle transazioni i Un Sistema di Gestione di Basi di Dati (DataBase Management System - DBMS) è
DettagliCap. 7 -Trigger e loro uso
1 SOMMARIO 2 Introduzione... 3 Definizione standard di trigger... 10 Cap. 7 -Trigger e loro uso Uso dei trigger e integrità referenziale... 18 Comportamento attivo delle BD Si realizza disponendo di un
DettagliBasi di dati attive. Paolo Atzeni Stefano Ceri. Basi di dati attive
Basi di dati attive Paolo Atzeni Stefano Ceri Basi di dati attive BD con componente per la gestione di regole Evento- Condizione-Azione (regole di produzione): eventi: normalmente modifiche della base
DettagliSistemi informativi D B M G. Introduzione. Introduzione alle basi di dati D B M G 2. Elena Baralis 2007 Politecnico di Torino 1
Sistemi informativi D B M G Introduzione D B M G 2 2007 Politecnico di Torino 1 Introduzione D B M G Gestione delle informazioni Base di dati Modello dei dati Indipendenza dei dati Accesso ai dati Vantaggi
DettagliLaboratorio di Basi di Dati SQL avanzato
Laboratorio di Basi di Dati SQL avanzato Pierluigi Pierini Technolabs S.p.a. Pierluigi.Pierini@technolabs.it Interrogazioni nidificate Syntax: SELECT {* [, ]} FROM [,
Dettagli06 Gestione delle transazioni
06 Gestione delle transazioni La transazione fornisce un meccanismo per descrivere le unità logiche di elaborazione delle basi di dati. I sistemi di gestione delle transazioni sono sistemi con grandi basi
DettagliTali regole vengono attivate in modo automatico al verificarsi di specifici eventi sulla. eseguono azioni sulla base di dati stessa.
Una base di dati è ATTIVA quando consente la definizione e la gestione di regole attive o trigger. Tali regole vengono attivate in modo automatico al verificarsi di specifici eventi sulla base di dati
DettagliDBMS architettura client/server
DBMS architettura client/server query DBMS utente risultato Molti utenti! biblioteca bibliotecario DBMS bibliotecario bibliotecario bibliotecario Parallelismo virtuale I vari utenti non si accorgono gli
DettagliBasi di Dati Attive. Basi di Dati Attive
Basi di Dati Passive le politiche di reazione nei vincoli d integrità referenziale sono il primo esempio della necessità di introdurre un comportamento reattivo nelle basi di dati mettendo a fattor comune
DettagliJDBC. Marco Tessarotto Programmazione dei Web Server Anno Accademico
JDBC Marco Tessarotto Programmazione dei Web Server Anno Accademico 2004-2005 JDBC JDBC (Java Database Connectivity) è una API Java per accedere ed elaborare dati in una sorgente dati (di solito un db
DettagliIl linguaggio SQL: transazioni
Il linguaggio SQL: transazioni Sistemi Informativi T Versione elettronica: 4.8.SQL.transazioni.pdf Cos è una transazione? Una transazione è un unità logica di elaborazione che corrisponde a una serie di
DettagliUniversita di Milano Bicocca Corso di Basi di dati 1 in elearning C. Batini 6. SQL DDL 6.2 Data Description Language - 2
Universita di Milano Bicocca Corso di Basi di dati 1 in elearning C. Batini 6. SQL DDL 6.2 Data Description Language - 2 Vincoli di integrita 2 Cosa e un vincolo di integrita E una proprieta sempre valida
DettagliBasi di dati II 21 febbraio 2017 Tempo a disposizione: un ora e quarantacinque minuti.
Tempo a disposizione: un ora e quarantacinque minuti. Cognome Nome Matricola Domanda 1 (15%) Considerare un sistema con dischi con N = 1000 blocchi per traccia tempo medio di posizionamento della testina
DettagliTRANSAZIONI TRANSAZIONI
TRANSAZIONI Concetto di transazione, comandi di transazione, proprietà ACID delle transazioni Transazioni concorrenti Esecuzione seriale e serializzabile Conflict-equivalenza, grafo dei conflitti Protocollo
DettagliBasi di dati vol.2 Capitolo 2 Gestione delle transazioni 20/05/2007
Basi di dati vol.2 Capitolo 2 Gestione delle transazioni 20/05/2007 1 DEFINIZIONE DI TRANSAZIONE Transazione: parte di programma caratterizzata da un inizio (begin-transaction, start transaction in SQL,
DettagliFondamenti di Teoria delle Basi di Dati
Fondamenti di Teoria delle Basi di Dati Riccardo Torlone Parte 1: Introduzione Obiettivi La conoscenza della teoria delle basi di dati? No (o non solo) Piuttosto: Come si può affrontare un problema in
DettagliL architettura di un DBMS
L architettura di un DBMS sources: Lucidi del corso di Lucidi del corso di Laboratorio di Basi di dati e sistemi informativi, Montesi, Magnani, Corso di laurea in Informatica per il management, Scienze
DettagliTecnologie Web T Gestione delle Transazioni e Livelli di Isolamento
Tecnologie Web T Gestione delle Transazioni e Livelli di Isolamento Home Page del corso: http://www-db.deis.unibo.it/courses/tw/ Versione elettronica: 4.03.Transazioni.pdf Versione elettronica: 4.03. Transazioni-2p.pdf
DettagliTRANSAZIONI DISTRIBUITE TRANSAZIONI
TRANSAZIONI DISTRIBUITE Transazioni distribuite Atomicità di una transazione distribuita Protocollo Two-Phase Commit Gestione dell affidabilità Fallimenti durante il 2PC Gestione della concorrenza Serializzabilità
DettagliTecnologia di un Database Server (centralizzato) Gestione dell affidabilità
Affidabilità Basi di Dati / Complementi di Basi di Dati 1 Tecnologia di un Database Server (centralizzato) Gestione dell affidabilità Angelo Montanari Dipartimento di Matematica e Informatica Università
DettagliBasi di dati attive. Paolo Atzeni. Basi di dati attive
Basi di dati attive Paolo Atzeni Basi di dati attive BD con componente per la gestione di regole Evento- Condizione-Azione (regole di produzione): eventi: normalmente modifiche della base di dati valuta
DettagliGestione delle transazioni
Basi di dati vol.2 Capitolo 2 Gestione delle transazioni 18/03/2009 DEFINIZIONE DI TRANSAZIONE Transazione: parte di programma caratterizzata da un inizio (begin-transaction, start transaction in SQL,
DettagliBasi di dati II. Gestione delle transazioni LE TRANSAZIONI. Definizione di transazione. Differenza fra applicazione e transazione
Basi di dati II 2- LE TRANSAZIONI 1 2 Definizione di transazione Differenza fra applicazione e transazione Transazione: parte di programma caratterizzata da un inizio (begin-transaction, start transaction
DettagliEsempio di sistema informativo
Basi di dati vol.2 Capitolo 2 Gestione delle transazioni 26/05/2005 Esempio di sistema informativo GESTIONE IMPIANTI IMMISSIONE DI ORDINI DI SERVIZIO CLIENTI GESTIONE ELENCHI ABBONATI GESTIONE RETE AMMINISTRAZIONE
DettagliTecnologia di un Database Server (centralizzato) Gestione del buffer
Buffer Basi di Dati / Complementi di Basi di Dati 1 Tecnologia di un Database Server (centralizzato) Gestione del buffer Angelo Montanari Dipartimento di Matematica e Informatica Università di Udine Buffer
DettagliTecnologia delle basi di dati (ex Basi di dati, primo modulo) 15 giugno 2005 Compito A Tempo a disposizione: due ore e quindici minuti
15 giugno 2005 Compito A Tempo a disposizione: due ore e quindici minuti Domanda 1 (25%) Siano r 1 ed r 2 due relazioni contenenti rispettivamente N 1 e N 2 ennuple, con fattore di blocco rispettivamente
DettagliBasi di dati II, primo modulo 24 giugno 2011 Compito breve
Basi di dati II, primo modulo 24 giugno 2011 Compito breve Cognome Nome Matricola Domanda 1 Come noto, si stanno diffondendo applicazioni nelle quali è necessaria una grande scalabilità e che vengono quindi
DettagliCREATE VIEW. CREATE VIEW <nome_vista> AS (SELECT <lista_campi> FROM <lista_tabelle> WHERE <condizione>);
SQL AVANZATO VIEW VISTE UTENTE VIEW (Viste utente) Le VIEW sono tabelle virtuali il cui contenuto (colonne e righe) è definito da una query Le VIEW sono normalmente utilizzate per: analizzare, semplificare
DettagliIntroduzione ai sistemi di basi di dati
Introduzione ai sistemi di basi di dati Corso di Basi di dati e laboratorio 1 Introduzione ai sistemi di basi di dati Angelo Montanari Dipartimento di Matematica e Informatica Università di Udine Introduzione
DettagliBasi di Dati. Concetti e Principi Generali. Maria Mirto
Basi di Dati Concetti e Principi Generali Maria Mirto Organizzazione dei Dati Archivi o file Procedure di accesso in qualunque linguaggio di programmazione Duplicazione dati: ridondanza incoerenza formati
DettagliBasi di dati II, primo modulo 24 giugno 2011 Compito breve Cenni sulle soluzioni
Basi di dati II, primo modulo 24 giugno 2011 Compito breve Cenni sulle soluzioni Cognome Nome Matricola Domanda 1 Come noto, si stanno diffondendo applicazioni nelle quali è necessaria una grande scalabilità
DettagliLezione 1. Introduzione ai sistemi di basi di dati
Lezione 1 Introduzione ai sistemi di basi di dati Pag.1 Testi consigliati Sistemi di Basi di Dati, di Raghu Ramakrishnan e Johannes Gehrke, McGraw Hill, 2004 (http://www.ateneonline.it/rama) Database Management
DettagliCAPITOLO 22 PROBLEMA DEL PRODUTTORE/CONSUMATORE
CAPITOLO 22 PROBLEMA DEL PRODUTTORE/CONSUMATORE Il problema del produttore/consumatore Il primo approccio alla risoluzione del problema del produttore/consumatore considera un buffer infinito presentato
DettagliGestione delle transazioni
Gestione delle transazioni Sistemi Informativi L-B Home Page del corso: http://www-db.deis.unibo.it/courses/sil-b/ Versione elettronica: transazioni.pdf Sistemi Informativi L-B Cos è una transazione? Una
DettagliBasi di dati Basi di dati per bioinformatica
Basi di dati Basi di dati per bioinformatica DOCENTI PROF. ALBERTO BELUSSI PROF CARLO COMBI Anno accademico 2013/14 Organizzazione degli insegnamenti 3 Basi di dati Basi di dati per Bioinformatica Teoria
DettagliBasi di Dati: Complementi Docente: Prof. Pierangela Samarati
Basi di Dati: Complementi Docente: Prof. Pierangela Samarati Appello di Maggio online 22 Maggio 2010 Tempo a disposizione 2:00h Soluzioni Domanda 1) Elencare e descrivere in modo completo le proprietà
DettagliAzioni atomiche. Definizioni. Proprietà
Azioni atomiche Definizioni Azione atomica: strumento di alto livello per strutturare programmi concorrenti e/o distribuiti, tolleranti a vari tipi di malfunzionamenti; o Realizzata con strumenti linguistici
DettagliTecnologie di Sviluppo per il Web
Tecnologie di Sviluppo per il Web Programmazione su Basi di Dati: Transazioni Parte b versione 3.0 Questo lavoro è concesso in uso secondo i termini di una licenza Creative Commons (vedi ultima pagina)
DettagliSQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)
1 SQL Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS) a.a. 2014/2015 http://www.di.uniba.it/~lisi/courses/basi-dati/bd2014-15.htm Dott.ssa Francesca A. Lisi dott.ssa Francesca A.
DettagliServlet & JDBC A L B E R T O B E L U S S I A N N O A C C A D E M I C O / Servlet: interazione con un DBMS
Servlet & JDBC 1 A L B E R T O B E L U S S I A N N O A C C A D E M I C O 2 0 1 0 / 2 0 1 1 Servlet: interazione con un DBMS In Java è possibile interagire con un DBMS attraverso l uso della libreria JDBC
DettagliBasi di dati. Docente Prof. Alberto Belussi. Anno accademico 2009/10
Basi di dati Docente Prof. Alberto Belussi Anno accademico 2009/10 Informazioni generali sull organizzazione Insegnamento annuale su due semestri Orario I Semestre Lunedì 11.30 13.30 (aula B) Martedì 11.30
DettagliDB - Cenni sulla gestione delle transazioni
transazioni Cenni sulla gestione delle transazioni in DBMS transazioni Cenni sulla gestione delle transazioni in DBMS Basato sulle slides di transazioni Cenni sulla gestione delle transazioni in DBMS Basato
DettagliBasi di dati II 25 febbraio 2014 Tempo a disposizione: due ore.
Basi di dati II 25 febbraio 24 Tempo a disposizione: due ore. Cognome Nome Matricola Ordin. Domanda (2%) Nella figura seguente è schematizzato un piccolissimo buffer con quattro pagine (numerate da a 3),
Dettagli