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

Requêtes MySQL Discussion :

Transactions multiples sous mysql


Sujet :

Requêtes MySQL

  1. #1
    Candidat au Club
    Inscrit en
    Juin 2006
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 5
    Points : 2
    Points
    2
    Par défaut Transactions multiples sous mysql
    Bonjour,

    j'ai une application développée en java, qui attaque une base mysql.
    Cette appli est multi-utilisateurs, et ouvre des transactions sur la base mysql.
    Or si 2 utilisateurs différents ouvre une transaction sur la meme table (mais sur des données différentes),
    et si l'un des 2 fait un update,
    l'autre devra attendre que le premier ferme sa transaction avant de pouvoir effectuer un update.
    Est ce normal?

    Est ce que MySQL gère les transactions multiples sur une meme table ?
    Si oui, comment faire?

    Merci d'avance pour votre aide.

  2. #2
    Membre émérite Avatar de Maximil ian
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 622
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 622
    Points : 2 973
    Points
    2 973
    Par défaut
    Salut,

    La gestion des accès concurrents dépend du moteur de stockage de tes tables.

    Le moteur MyISAM utilise un verrouillage au niveau table ce qui fait qu'effectivement un UPDATE sur une table bloque toute autre requête sur cette table tant qu'il n'est pas terminé.

    Le moteur InnoDB verrouille au niveau ligne (donc moins de problèmes de ce côté-là) et implémente les transactions ACID avec différents niveaux de visibilité entre les transactions qui s'exécutent en même temps.

    cf http://mysql.developpez.com/faq/?pag...antages_innodb
    http://dev.mysql.com/doc/refman/5.0/...l-locking.html
    Pensez au bouton

  3. #3
    Candidat au Club
    Inscrit en
    Juin 2006
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 5
    Points : 2
    Points
    2
    Par défaut
    Justement mes tables sont bien en innodb, dc je ne pensais pas avoir de pb.

    Faut-il faire qqch de spécial ds la configuration pour que cela fonctionne correctement ?

  4. #4
    Membre régulier Avatar de jp_rennes
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    72
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mars 2006
    Messages : 72
    Points : 86
    Points
    86
    Par défaut
    tout dépend de la variable :
    mysql> show variables like '%isolation%';
    +---------------+-----------------+
    | Variable_name | Value |
    +---------------+-----------------+
    | tx_isolation | REPEATABLE-READ |
    +---------------+-----------------+
    1 row in set (0.00 sec)

    cette variable spécifie si tu bloque ou pas la ligne en lecture et/ou écriture pour les autres transactions....

    va voir http://dev.mysql.com/doc/refman/5.0/...isolation.html

Discussions similaires

  1. Transaction sous MySQL
    Par GDev80 dans le forum SQL Procédural
    Réponses: 0
    Dernier message: 23/02/2011, 16h45
  2. Réponses: 2
    Dernier message: 14/04/2008, 10h24
  3. Utilisation d'une transaction sous Mysql 5.0
    Par sanqara dans le forum Administration
    Réponses: 1
    Dernier message: 22/07/2006, 14h37
  4. Problème de création de table sous MySql
    Par ducamba dans le forum Requêtes
    Réponses: 2
    Dernier message: 21/06/2003, 09h59
  5. Comment afficher les accent sous mysql v4.0.13
    Par buildozer dans le forum Requêtes
    Réponses: 2
    Dernier message: 17/06/2003, 09h33

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