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

Connexion aux bases de données Firebird Discussion :

lock conflict sur une req select


Sujet :

Connexion aux bases de données Firebird

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 6
    Points : 4
    Points
    4
    Par défaut lock conflict sur une req select
    Bonjour à tous,
    j'utilise firebird et java.
    dans mon source, je fais un 'select . from . where' tout simple , et la requete déclenche une erreur 'lock conflict on no wait transaction
    deadlock'.
    Il y a surement une des lignes de cette table qui est locke par un autre utilisateur. Mais je ne fais qu'un select et ma connection est en read only, je ne devrais pas avoir de lock conflict.
    Auriez vous une idée pour moi ?
    merci d'avance

  2. #2
    Membre expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 048
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 048
    Points : 3 342
    Points
    3 342
    Par défaut
    C'est systématique ?
    Ca le fait sous ISQL aussi ? (en prenant la même requete)

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 6
    Points : 4
    Points
    4
    Par défaut
    Je n'ai pas essayé sous ISQL, mais je vais le faire et je vous dis

    En fait je travaille aussi avec du jsp et un serveur tomcat, le problème c'est que cette erreur se produit lorsque mon client travaille avec mon programme jsp et je n'ai pas encore réussi ( ou pris le temps) de reproduire vraiment cette erreur vu que j'ai plus ou moins inhibé cette erreur pour qu'il puisse tourner.

    Merci.

  4. #4
    Membre expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 048
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 048
    Points : 3 342
    Points
    3 342
    Par défaut
    Et aussi, quel est le type de la transaction dans lequel votre select s'effectue ?

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 6
    Points : 4
    Points
    4
    Par défaut
    Voila comment j'initialise mes connections en source java pour le select.

    Code java : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        int [] tp = {org.firebirdsql.gds.ISCConstants.isc_tpb_version3
         , org.firebirdsql.gds.ISCConstants.isc_tpb_read_committed
         , org.firebirdsql.gds.ISCConstants.isc_tpb_nowait
         , org.firebirdsql.gds.ISCConstants.isc_tpb_read };
     
          ((org.firebirdsql.jdbc.FirebirdConnection)conn).setTransactionParameters(org.firebirdsql.jdbc.FirebirdConnection.TRANSACTION_READ_COMMITTED, tp);
          conn.setAutoCommit(false);

    Si quelqu'un connait des sites ou de la doc sur firebird ( plus en français), ou jdbc qui puisse m'aider.
    J'ai un peu navigué mais n'est pas trouvé grand chose d'interressant..

    Je vais essayer sous ISQL, mais le problème c'est que je ne sais pas exactement quelle requete a mis en with lock un des enregistrements.
    Merci.

  6. #6
    Membre expert
    Avatar de Barbibulle
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    2 048
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 2 048
    Points : 3 342
    Points
    3 342
    Par défaut
    L'isolation de votre transaction est Read_commited, mais dans ce mode il faut préciser un autre paramétre.
    Car par defaut il est à no_rec_version, or dans ce mode, si une autre transaction modifie un enregistrement (mais ne le commit pas encore) la lecture de celui-ci vous retournera une erreur de lock conflict.
    Il faut que vous précisez rec_version qui permet dans le même cas de lire la dernière version commitée de l'enregistrement.

    Mais bon c'est un choix :
    Soit vous utilisez le no_rec_version et si vous avez un erreur vous savez qu'une personne est en train de modifier l'enregistrement mais ne l'a pas encore commité. Donc vous réésseyez plus tard et vous êtes certainne d'avoir les données les plus à jours possible.

    Soit vous utilisez le rec_version et dans ce cas vous n'avez pas de probleme de lecture mais par contre ce que vous lisez est peut etre en cours de modification (non validée) et vous ne le savez pas.

    Donc pour évitez résoudre votre PB faites :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        int [] tp = {org.firebirdsql.gds.ISCConstants.isc_tpb_version3
         , org.firebirdsql.gds.ISCConstants.isc_tpb_read_committed
         , org.firebirdsql.gds.ISCConstants.isc_tpb_rec_version
         , org.firebirdsql.gds.ISCConstants.isc_tpb_nowait
         , org.firebirdsql.gds.ISCConstants.isc_tpb_read };
     
          ((org.firebirdsql.jdbc.FirebirdConnection)conn).setTransactionParameters(org.firebirdsql.jdbc.FirebirdConnection.TRANSACTION_READ_COMMITTED, tp);
          conn.setAutoCommit(false);

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 6
    Points : 4
    Points
    4
    Par défaut
    Merci beaucoup pour ta réponse
    je vais le faire

Discussions similaires

  1. Transparence sur une balise select IE6
    Par rellik45 dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 18/07/2007, 18h03
  2. [AJAX] Aide à la recherche sur une liste <select>
    Par lthibert dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 16/06/2007, 13h00
  3. title sur une balise select
    Par delas dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 16/06/2006, 11h37
  4. transformation sur une requete SELECT
    Par juniorAl dans le forum Langage SQL
    Réponses: 8
    Dernier message: 08/04/2005, 18h12
  5. Trie sur une requette SELECT
    Par Yali dans le forum Langage SQL
    Réponses: 6
    Dernier message: 13/08/2004, 09h56

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