Les transactions. Bases de Données. Année

Documents pareils
Cours Bases de données 2ème année IUT

Cours Bases de données 2ème année IUT

Bases de données et sites WEB Licence d informatique LI345

Langage propre à Oracle basé sur ADA. Offre une extension procédurale à SQL

COMMANDES SQL... 2 COMMANDES DE DEFINITION DE DONNEES... 2

Notes de cours : bases de données distribuées et repliquées

Les transactions 1/46. I même en cas de panne logicielle ou matérielle. I Concept de transaction. I Gestion de la concurrence : les solutions

Gestion des transactions et accès concurrents dans les bases de données relationnelles

Langage SQL (1) 4 septembre IUT Orléans. Introduction Le langage SQL : données Le langage SQL : requêtes

ECR_DESCRIPTION CHAR(80), ECR_MONTANT NUMBER(10,2) NOT NULL, ECR_SENS CHAR(1) NOT NULL) ;

Partie I : Créer la base de données. Année universitaire 2008/2009 Master 1 SIIO Projet Introduction au Décisionnel, Oracle

Module Administration BD Chapitre 1 : Surcouche procédurale dans les SGBDS

Les Triggers SQL. Didier DONSEZ. Université de Valenciennes Institut des Sciences et Techniques de Valenciennes

Licence de MIDO - 3ème année Spécialités Informatique et Mathématiques Appliquées

ISC Système d Information Architecture et Administration d un SGBD Compléments SQL

BTS/CGO P10 SYSTEME INFORMATION Année

SQL Historique

TP Contraintes - Triggers

Intégrité des données

A QUOI SERVENT LES BASES DE DONNÉES?

ORACLE 10G DISTRIBUTION ET REPLICATION. Distribution de données avec Oracle. G. Mopolo-Moké prof. Associé UNSA 2009/ 2010

PHP. Bertrand Estellon. 26 avril Aix-Marseille Université. Bertrand Estellon (AMU) PHP 26 avril / 214

Bases de données relationnelles

SGBDR. Systèmes de Gestion de Bases de Données (Relationnelles)

IFT3030 Base de données. Chapitre 1 Introduction

Devoir Data WareHouse

Les bases de données

Procédures Stockées WAVESOFT ws_sp_getidtable Exemple : ws_sp_getnextsouche Exemple :... 12

Compétences Business Objects

Administration des bases de données. Jean-Yves Antoine

Intégrité sémantique dans les bases de données relationnelles

Olivier Mondet

La replication dans PostgreSQL

Comprendre les bases de données

1. Base de données SQLite

Bases de données avancées

Sommaire. Etablir une connexion avec une base de données distante sur PostGreSQL

TP3 : Creation de tables 1 seance

Réplication des données

CREATION WEB DYNAMIQUE

Les bases de l optimisation SQL avec DB2 for i

Cours de Base de Données Cours n.12

Bases de Données relationnelles et leurs systèmes de Gestion

Le langage SQL pour Oracle - partie 1 : SQL comme LDD

A QUOI SERVENT LES BASES DE DONNÉES?

BASES DE DONNEES TP POSTGRESQL

1. Qu'est-ce que SQL? La maintenance des bases de données Les manipulations des bases de données... 5

Cours 3. Développement d une application BD. DBA - Maîtrise ASR - Université Evry

OpenPaaS Le réseau social d'entreprise

PHP 5. La base de données MySql. A. Belaïd 1

Mysql. Les requêtes préparées Prepared statements

Session S12 Les bases de l optimisation SQL avec DB2 for i

Bases de données Oracle Virtual Private Database (VPD) pour la gestion des utilisateurs d applications

Bases de données avancées Concurrence d'accès et reprise

Corrigés détaillés des exercices

Plan Général Prévisionnel (1/2) (non contractuel) Internet et Outils L1/IO S2-IO2 Bases de données: Jointures, Transactions

Département Génie Informatique

Présentation du module Base de données spatio-temporelles

Bases de données et sites WEB

Quelques aspects du Relationnel-Objet du SGBD Oracle

Gestion des droits d accès. Quelques exemples de vulnérabilité

Le langage SQL (première partie) c Olivier Caron

Gestion de base de données

Présentation Windows Azure Hadoop Big Data - BI

Laboratoires de bases de données. Laboratoire n 6. Programmation SQL. par Danièle BAYERS et Louis SWINNEN

Encryptions, compression et partitionnement des données

PL langage de programmation côté serveur. SQL à la base : types, expressions, requêtes

Bases de Données Réparties

FileMaker 13. Guide de référence SQL

Création et Gestion des tables

Réplication E-maj Foreign Data Wrapper PostGIS PostgreSQL-f

Bases de Données Réparties Concepts et Techniques. Matthieu Exbrayat ULP Strasbourg - Décembre 2007

Langage SQL : créer et interroger une base

MODE OPERATOIRE CORIM PROGRESS / SECTION MEI. Exploitation Informatique

Java DataBaseConnectivity

CHAPITRE 4 POLITIQUES DE CONTRÔLES DES ACCÈS SOUS ORACLE ADMINISTRATION ET TUNING DE BASES DE DONNÉES 10/05/2015 RESPONSABLE DR K.

Gestion des utilisateurs et de leurs droits

Synchronisation Mysql (Replication)

Django et PostgreSQL sous la charge

Partie II Cours 3 (suite) : Sécurité de bases de données

PROJET 1 : BASE DE DONNÉES REPARTIES

14/04/2014. un ensemble d'informations sur un sujet : exhaustif, non redondant, structuré, persistant. Gaëlle PERRIN SID2 Grenoble.

A.E.C. GESTION DES APPLICATIONS TECHNOLOGIE DE L'INFORMATION LEA.BW

Plan. Bases de Données. Sources des transparents. Bases de SQL. L3 Info. Chapitre 4 : SQL LDD Le langage de manipulation de données : LMD

Les déclencheurs. Version 1.0. Grégory CASANOVA

Implémentation des SGBD

Bases de données cours 4 Construction de requêtes en SQL. Catalin Dima

1 Modélisation d une base de données pour une société de bourse

Les Utilisateurs dans SharePoint

Sécurité des applications web. Daniel Boteanu

SQL. Oracle. pour. 4 e édition. Christian Soutou Avec la participation d Olivier Teste

TD : Requêtes SQL (BDR.TD2-1) INSA 3IF

Introduction à JDBC. Accès aux bases de données en Java

Bases de Données Avancées

L objet de cet article est de présenter succinctement ces possibilités.

Chapitre 10. Architectures des systèmes de gestion de bases de données

1. Qu'est qu'un tablespace?

Transcription:

Les transactions Bases de Données Année 2007-08 Généralités une transaction : suite d opérations sur la base qui ne conservent la cohérence des données que lorsqu elles sont toutes effectuées. Exemples : emprunt de livres Lorsqu un adhérent rend un livre, on va supprimer l enregistrement correspondant de la table emprunt pour créer un enregistrement dans la table histoemprunt opérations bancaires Lors d un virement de compte à compte, on doit débiter une somme sur un compte avant de la créditer sur un autre. Généralités Que se passe-t-il s il arrive un problème entre les opérations? D autant que les problèmes peuvent être de nature différentes : panne logicielle (rupture du réseau...) incohérence des données (le premier compte ne contient même pas la somme à débiter...) Nécessité de préciser que les opérations appartiennent à une même transaction : la transaction complète réussit et toutes les opérations sont effectuée sur la base, ou bien la transaction échoue, et toutes les opérations sont annulées. Généralités Une transaction commence par le mot-clé begin, ou begin work,ou begin transaction,ou start transaction, et termine soit par un succès : commit soit par un échec : rollback Exemples loca=# begin ; BEGIN loca=# select couleur from voiture where id_voiture = 4 ; couleur 1

--------- vert loca=# update voiture set couleur = rose where id_voiture = 4 ; UPDATE 1 loca=# commit ; COMMIT loca=# select couleur from voiture where id_voiture = 4 ; couleur --------- rose Exemples loca=# begin ; BEGIN loca=# select * from voiture where id_voiture = 4 ; id_voiture num_immatriculation id_modele couleur ------------+---------------------+-----------+--------- 4 2345 FG 78 1 rose loca=# update voiture set couleur = mauve where id_voiture = 4 ; UPDATE 1 loca=# rollback ; ROLLBACK loca=# select * from voiture where id_voiture = 4 ; id_voiture num_immatriculation id_modele couleur ------------+---------------------+-----------+--------- 4 2345 FG 78 1 rose Exemples Une erreur annule une transaction... Exemples location=# begin ; BEGIN location=# select couleur from voiture where id_voiture = 4 ; rose location=# update voiture set couleur = rose à pois bleus ; ERROR : value too long for type character varying(10) location=# update voiture set couleur = grise ; ERROR : current transaction is aborted, 2

queries ignored until end of transaction block location=# commit ; COMMIT location=# select couleur from voiture where id_voiture = 4 ; rose Généralités Quelques remarques : ne pas confondre begin qui démarre une transaction et begin le mot-clé PLSQL qui indique le début d une fonction ; pas de transactions imbriquées en PostgreSQL ; de ce fait, pas de commit ou de rollback à l intérieur d une fonction ; jusqu à présent : travail avec l option autocommit. Chaque instruction SQL est une transaction. Généralités Dans la base mapetiteentreprise vue en interro : commerce=#begin ; BEGIN commerce=#select creefacture(3) ; creefacture ------------ (1 ligne) commerce=# commit ; COMMIT Vers les accès concurrents Les étapes intermédiaires d une transaction ne sont pas visibles par les autres utilisateurs. Vers les accès concurrents loca=# begin ; loca=# update voiture set couleur= vert where id_voiture=4 ; UPDATE 1 loca=# loca=# select couleur from voiture where id_voiture=4 ; couleur 3

--------- rose loca=#commit ; COMMIT loca=# loca=# select couleur from voiture where id_voiture=4 ; couleur --------- vert Quelle vision des données? Effets des accès concurrents sur la lecture de données : lecture sale : une transaction lit des données écrites par une transaction concurrente non validée ; lecture non reproductible : une transaction relit des données et obtient des données modifiées (à cause d une transaction concurrente validée) ; lecture d enregistrements fantômes : une transaction re-exécute une requête et obtient un ensemble d enregistrements différents (à cause d une transaction concurrente validée) Le standard SQL définit 4 niveaux d isolation des transactions. Niveau d isolation lect. sale lec. non repr. lect. fant. read uncommited possible possible possible read commited impossible possible possible repeatable read impossible impossible possible serializable impossible impossible impossible PostgreSQL fournit les niveaux read commited et serializable. Chaque session concurrente voit un cliché de la base. Le résultat des requêtes dépend donc du moment où est pris le cliché. read commited : cliché pris en début de chaque requête, sur des modifications validées cas d une requête R update ou delete : si une transaction B concurrente accède en modification les mêmes enregistrements alors R bloquée jusqu à validation ou annulation de B conditions de recherche sont ré-évaluées pour les enregistrements satisfaisant R : R effectuée pour ceux satisfaisant toujours les critères Exemple avec deux update concurrents. 4

temps session A session B t ex=# begin ; ex=# begin ; BEGIN BEGIN t+1 ex=# update voiture set couleur= rose where id_voiture=1 ; t+2 UPDATE 1 t+3 ex=# update voiture set nom = truc where id_voiture=1 ;... -- requ^ete bloquée!! t+10 ex=# commit ; t+11 COMMIT UPDATE 1 t+12 ex=# commit ; t+13 COMMIT Exemple avec un insert et un update concurrents. temps session A session B t ex=# begin ; ex=# begin ; BEGIN BEGIN t+1 ex#= select count(id_voiture) from voiture t+2 ex=# insert into voiture where couleur = rose ; (couleur) count values( rose ) ; ------ INSERT 1 3 t+3 ex=# update voiture set couleur = mauve where couleur = rose t+4 ex=# commit ; UPDATE 3 t+5 COMMIT t+6 ex=# commit ; t+7 COMMIT Exemple avec un update et un delete concurrents. 5

temps session A session B t ex=# begin ; ex=# begin ; BEGIN BEGIN t+1 ex=# select couleur from ex#= select count(id_voiture) voiture where from voiture id_voiture = 3 ; where couleur = rose ; t+2 couleur count -------- ------ rose 3 t+3 ex=# delete from voiture t+4 where id_voiture=3 ; ex=# update voiture DELETE 1 set couleur = mauve where couleur = rose t+5 ex=# commit ; -- requ^ete bloquée!! t+6 COMMIT UPDATE 2 t+7 ex=# commit ; t+8 COMMIT Attention : au niveau d isolation read committed, comme deux select qui se suivent ne voient pas la même version de la base, cela peut donner des incohérences au niveau de la transaction. Incohérences au niveau read commited temps session A session B t ex=# begin ; ex=# begin ; -- et BEGIN BEGIN -- entrée ds une fct plpgsql t+1 ex=# select couleur ex#= select count(id_voiture) from voiture into nb1 where id_voiture=3 ; from voiture couleur where couleur = rose ; t+2 ------- count rose ------ 3 Incohérences au niveau read commited ex=# delete from voiture t+3 where id_voiture=3 ; t+4 DELETE 1 ex=# select count(*) into nb2 from voiture ; 6

count t+5 ex=# commit ; ------ t+6 COMMIT 10 ex=# return nb1/nb2 ; t+7 ex=# commit ; t+8 COMMIT Serializable : le niveau le plus strict d isolation. cliché de la base pris au début de la première requête de la transaction conservé pour toute la durée de la transaction ordre update ou delete : si modification des enregistrements par une transaction concurrente, la transaction échoue = nécessité de retenter des transactions échouées transactions qui n effectuent que des lectures n ont jamais de conflits, et proposent une vue complètement cohérente sur toute la transaction. Les verrous Pour le moment, on reste dans le principe une écriture ne bloque pas une lecture une lecture ne bloque pas une écriture Pas toujours satisfaisant... drop table ne peut pas être exécuté en concurrence avec d autres opérations ; base mapetiteentreprise création d une facture ; Les verrous On ajoute des verrous, implicitement ou explicitement, sur les tables ou les enregistrements. un verrou peut être posé implicitement (par un ordre SQL) ou explicitement (ordre lock table [in verrou mode mode]) un verrou est acquis jusqu à la fin de la transaction (limitation Postgres) Les verrous deux types de verrous : sur une table complète, ou sur des enregistrements d une table hiérarchie sur les verrous (de très contraignant à très permissif) la priorité sur les verrous est donnée suivant leur ordre chronologique les noms sont historiques! clé : exclusive : empêche le même type de verrou d être posé en même temps ; share : accepte la pose d un même type de verrou 7

Les verrous de table Du plus exclusif au plus permissif. Tous ces verrous peuvent être acquis de manière explicite. Access Exclusive conflit avec tous les autres modes. Acquis par drop table, alter table, vacuum full, ou bien lock table sans précisions! Exclusive accepte seulement les verrous Access Share, i.e. les select. N est acquis implicitement par aucun ordre SQL Les verrous de table Share Row Exclusive accepte les accès concurrents en consultation uniquement (select avec ou sans clause for update)(conflit avec tous les autres modes). N est acquis implicitement par aucun ordre SQL Share acquis par create index, idem que le précédent mais non exclusif ; Share Update Exclusive acquis par vacuum, conflit avec les quatre verrous précédents, et lui-même : protège contre les vacuum concurrents et les modifications de schémas de table (alter table) Les verrous de table Row Exclusive acquis par update, delete, insert, conflit avec les quatre premiers verrous, et lui-même Row Share acquis par select for update, conflit avec les deux premiers verrous (Access Exclusive et Exclusive) Access Share acquis par select, conflit avec le premier verrou (Access Exclusive) Les verrous d enregistrements Limitent l effet du verrouillage au niveau des enregistrements accédés, pas de la table complète. acquis par une modification, une suppression ou une sélection pour miseà-jour (update, delete, select for update) ; jusqu à la fin de la transaction ; ne bloquent pas la lecture (select) bloquent l écriture sur ces enregistrements select for update permet de poser un tel verrou sans modifier les données Cas d utilisations On veut, pour une transaction, consulter des données sans qu elles ne soient modifiées en cours de route. = verrou en mode Share Refuse toute écriture, accepte d autres verrous en mode Share si une écriture est en cours...on est bloqué! lorsqu on acquiert le verrou, on empêche toute mise-à-jour jusqu à la fin de la transaction 8

Cas d utilisations Temps Session A Session B t bd=#begin ; bd=#begin ; BEGIN BEGIN t+1 bd=#update XXX ; UPDATE t+2 bd=#lock table XXX in share mode ; -- requ^ete bloquée t+4 bd=# commit ; COMMIT LOCK TABLE t+5 bd=# update XXX ; bd=# select... -- requ^ete bloquée Les deadlocks Même cas de figure, mais on en profite pour mettre à jour les données. Temps Session A Session B t bd=#begin ; bd=#begin ; BEGIN BEGIN t+1 bd=#lock table XXX bd=#lock table XXX in share mode ; in share mode ; LOCK TABLE LOCK TABLE t+2 bd=# select XXX... ; bd=# select XXX... ; -- OK! -- OK! t+3 bd=# update XXX ; -- requ^ete bloquée! t+4 bd=# update XXX... ; -- erreur! deadlock détecté t+5 UPDATE -- verrou levé... Cas d utilisations il fallait poser un verrou en mode share row exclusive en cas de deadlock, on ne peut pas prédire quel verrou sera levé est-ce une bonne idée de poser un verrou restrictif dans une transaction qui attend des réponses de l utilisateur? on veut faire une insertion sur une table après avoir récupéré la valeur d une clé étrangère qu on doit utiliser dans l insertion. Doit-on utiliser un verrou, et si oui, lequel? 9

Cas d utilisations Les verrous les plus fréquemment utilisés (explicitement) : share mode pour des lectures cohérentes ; share row exclusive mode pour des lectures cohérentes sans souci de deadlock pour l écriture de données 10