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

Servlets/JSP Java Discussion :

Gérer l'accès simultané à la BD


Sujet :

Servlets/JSP Java

  1. #1
    Membre à l'essai
    Inscrit en
    Février 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 32
    Points : 24
    Points
    24
    Par défaut Gérer l'accès simultané à la BD
    Voilà que j'avançais bien mon projet Web je heurte dans un mure



    Puisque les utilisateurs vont pouvoir modifier une donnée simultanément dans la base de données je me suis posé la question comment gérer l'accès de manière pertinente?

    Donc j'ai consulté différents tutos et finalement pas d'idée claire!
    Je ne veux pas utiliser un framework et je cherche une autre solution. Exemple vérou de la ligne en modification...mais puisque ce n'est qu'une idée je voudrais avoir vos conseils sur le sujet si possible avec mini exemple.

    Comment faire pour ne pas avoir des incohérences? Faut - il utiliser de thread?
    J'utilise tomcat 5.5, MySql, Eclipse europe WTP...

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Soit tu locke l'accès (à toi de voir comment, c'est faisable avec une table de locking en sql ou avec des select for update) avant d'éditer. Avantage, t'es certain que deux personnes ne modifie pas en même temps. Inconvénient, si la personne qui a locké "disparait" ou va prendre sa pause déjeuner, elle bloque tout le monde.

    Soit tu stocke dans la session utilisateur le row dans son état avant édition et, au moment de l'update, tu check dans la même transaction que l'update que l'état n'a pas changé (select for update et comparaison). L'avantage c'est que le verrou n'est obtenu que pendant les quelque millisecondes de l'update. L'inconvénient, c'est que si deux personnes éditent en même temps, la deuxième à envoyer ses données recevra un joli "pas d'accord, t'as fait çà pour rien" dans la gueule.

  3. #3
    Membre à l'essai
    Inscrit en
    Février 2007
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 32
    Points : 24
    Points
    24
    Par défaut
    Merci tchize_.
    Je test cela ce soir et je tiens tout le monde au courant.

Discussions similaires

  1. Accès simultanés : bloquer la lecture d'une table
    Par rohstev dans le forum Access
    Réponses: 12
    Dernier message: 01/02/2008, 20h04
  2. [Axis][WebService]accès simultanés à un Webservice
    Par olivierda dans le forum Services Web
    Réponses: 6
    Dernier message: 08/12/2006, 18h36
  3. Gérer les accès concurrents
    Par Royd938 dans le forum Langage
    Réponses: 1
    Dernier message: 19/10/2005, 11h27
  4. [SQLServer] Acces simultanés a une BD via ADO dans un dll
    Par corwin_d_ambre dans le forum Bases de données
    Réponses: 4
    Dernier message: 05/11/2004, 15h52
  5. Réponses: 7
    Dernier message: 08/03/2004, 15h30

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