IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MySQL Discussion :

Transactions parallèles via deux connexions


Sujet :

MySQL

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    67
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2015
    Messages : 67
    Points : 108
    Points
    108
    Par défaut Transactions parallèles via deux connexions
    Salut je me pose une question par rapport aux transactions.

    Admettons, j'ai deux connexions (c1 et c2) ouvertures sur la même bdd, les deux font une transaction pour insérer des données au même moment pas forcément dans la même table. Les transactions seront-elles bien parallèles ou séquentielles ?

    Si parallèle, que se passerait-il si c1 insérait ses données mais n'avait pas encore commit et que c2 échouait et lançait donc un rollback plus vite que le commit de la transaction de c1. Au final, la table ne serait pas modifiée puisque le rollback a été fait avant le commit, si on en suit cette logique.

    Merci pour vos réponses.

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 772
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 772
    Points : 52 732
    Points
    52 732
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par kopbuc Voir le message
    Salut je me pose une question par rapport aux transactions.

    Admettons, j'ai deux connexions (c1 et c2) ouvertures sur la même bdd, les deux font une transaction pour insérer des données au même moment pas forcément dans la même table. Les transactions seront-elles bien parallèles ou séquentielles ?
    Les bases de données ne sont pas des manipulations de fichier à la COBOL... Le parallélisme y est effectif même au sein d'une seule et unique table. Cependant, certains SGBDR sont mieux lotis que d'autres en cette matière (c'est pourquoi certains sont gratuits, et d'autres très couteux...). Voir les benchmarks du TPC et en particulier le TPC E

    Si parallèle, que se passerait-il si c1 insérait ses données mais n'avait pas encore commit et que c2 échouait et lançait donc un rollback plus vite que le commit de la transaction de c1. Au final, la table ne serait pas modifiée puisque le rollback a été fait avant le commit, si on en suit cette logique.

    Merci pour vos réponses.
    Chaque transaction est isolée les une des autres en fonction des propriété ACID des transactions et notamment du niveau d’isolation choisit. Néanmoins, la finalisation d'une transaction n'a aucune incidence sur le mode de finalisation d'une autre, sauf si les données de l'une dépendant de l'autre.. Je vous invite à lire mon cours :
    https://sqlpro.developpez.com/isolation-transaction/

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    67
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2015
    Messages : 67
    Points : 108
    Points
    108
    Par défaut
    Citation Envoyé par SQLpro Voir le message

    Chaque transaction est isolée les une des autres en fonction des propriété ACID des transactions et notamment du niveau d’isolation choisit. Néanmoins, la finalisation d'une transaction n'a aucune incidence sur le mode de finalisation d'une autre, sauf si les données de l'une dépendant de l'autre.. Je vous invite à lire mon cours :
    https://sqlpro.developpez.com/isolation-transaction/

    A +
    Super merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] deux connexions mySql en parallèle
    Par sanatou dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 28/05/2008, 15h23
  2. Gestion de deux connexions internet
    Par ePoX dans le forum Dépannage et Assistance
    Réponses: 13
    Dernier message: 08/04/2007, 11h08
  3. Comment contrôler le port parallèle via ioctl
    Par nico2022 dans le forum Linux
    Réponses: 2
    Dernier message: 28/02/2007, 10h28
  4. Deux connexions TCP entre un serveur et un client ?
    Par innosang dans le forum Développement
    Réponses: 4
    Dernier message: 18/12/2006, 00h33
  5. Deux connexion internet
    Par MI-K@ dans le forum Dépannage et Assistance
    Réponses: 4
    Dernier message: 16/10/2006, 11h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo