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

Bases de données Delphi Discussion :

Erreur firebird: invalid transaction handle (expecting explicit transaction start)


Sujet :

Bases de données Delphi

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juillet 2006
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 42
    Points : 34
    Points
    34
    Par défaut Erreur firebird: invalid transaction handle (expecting explicit transaction start)
    Salut

    J'ai une appli en delphi qui essaye d'insérer, via plusieurs threads, des lignes dans une base de données FireBird: quand le nombre de threads est bas (une dizaine) , j'ai aucun problème, mais quand il atteint la vingtaine, j'ai ce message d'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     firebird invalid transaction handle (expecting explicit transaction start)
    J'utilise les composants IBX de delphi : une requête paramètrée associée à une transaction (fbtrans).

    Quel est le problème?

    Merci d'avance

  2. #2
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    Bon d'abord t'es pas dans le bon forum Il y a un forum Delphi et bases de données.

    Sinon vérifie que la transaction est belle et bien créée. Peut-être que ton serveur ne supporte simplement pas trop de connexions simultanées (ça doit pouvoir se changer dans la conf, c'est pas une limitation de FB) : il pourrait alors refuser les nouvelles transactions.

    Si IBX n'est pas avertit que la création de la transaction a échoué (problème de protocole entre IBX et FB), il se peut que StartTransaction ne déclenche pas d'exception, mais que le handle de la connexion soit invalide.

    Ce ne sont que des hypothèses, je n'ai jamais eu à traiter ce genre de problème.
    sjrd, ancien rédacteur/modérateur Delphi.
    Auteur de Scala.js, le compilateur de Scala vers JavaScript, et directeur technique du Scala Center à l'EPFL.
    Découvrez Mes tutoriels.

  3. #3
    Nouveau membre du Club
    Inscrit en
    Juillet 2006
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 42
    Points : 34
    Points
    34
    Par défaut Résolu :)
    Citation Envoyé par sjrd
    Sinon vérifie que la transaction est belle et bien créée. Peut-être que ton serveur ne supporte simplement pas trop de connexions simultanées (ça doit pouvoir se changer dans la conf, c'est pas une limitation de FB) : il pourrait alors refuser les nouvelles transactions.

    Si IBX n'est pas avertit que la création de la transaction a échoué (problème de protocole entre IBX et FB), il se peut que StartTransaction ne déclenche pas d'exception, mais que le handle de la connexion soit invalide.

    Ce ne sont que des hypothèses, je n'ai jamais eu à traiter ce genre de problème.
    Merci de l'aide
    En fait, j'ai fait une bêtise à la création de ma requête en runtime:
    au début, je faisais comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    var
    MaRequete: TIBQuery;
    MaTransaction: TIBTransaction
    begin
     MaRequete.Create(nil);
     MaTransaction.Create(nil);
      //Assignation des diiférents propriétés de la query et de la transaction
      //DefaultDatabase, Database....
    end
    Alors que normalement, je devrais m'y prendre ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     MaRequete := TIBQuery.Create(nil)
     MaTransaction := TIBTransaction.Create(nil);
     //Assignation des diiférents propriétés de la query et de la transaction
     //DefaultDatabase, Database....
    ou tout simplement directement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     with TIBQuery.Create(nil) do
     begin
      //Assignation des diiférents propriétés de la query
     end
    Merci pour votre aide et à la prochaine

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 10/10/2008, 12h21
  2. Invalid transaction handle (expecting explicit transaction start)
    Par WebPac dans le forum Bases de données
    Réponses: 9
    Dernier message: 25/06/2007, 18h04
  3. [Delphi - Firebird] Comment faire bon usage des transactions?
    Par Lili21 dans le forum Connexion aux bases de données
    Réponses: 2
    Dernier message: 07/05/2007, 20h59
  4. Erreur 3271 invalid property value
    Par schwinny dans le forum Access
    Réponses: 2
    Dernier message: 12/07/2006, 11h17
  5. Réponses: 2
    Dernier message: 10/11/2004, 12h21

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