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

Interfaces de programmation Oracle Discussion :

[OCILIB] Multithread et gestion des erreurs


Sujet :

Interfaces de programmation Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Architecte technique
    Inscrit en
    Août 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2009
    Messages : 12
    Par défaut [OCILIB] Multithread et gestion des erreurs
    Bonsoir,

    J'ai besoin d'un éclaircissement sur le multithread et la gestion des erreurs avec OCILIB 3.5.0.0. Le contexte:

    • Le programme gère le multithread lui-même. Il n'utilise pas les threads proposés par OCILIB.
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      OCI_Initialize( NULL, NULL, OCI_ENV_THREADED | OCI_ENV_CONTEXT )
      Le programme gère son propre pool de connexion à la bdd. Une connexion pour chaque thread, ouverte au démarrage du thread et fermée avec son arrêt.
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      OCI_ConnectionCreate(parametre->OracleSid().c_str(), parametre->OracleUser().c_str(), parametre->OraclePwd().c_str(), OCI_SESSION_DEFAULT)


    Plus tard, arrive le moment décisif d'une insertion. Fait important le programme ne travaille que sur des tableaux.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    iNbRowsInArray = OCI_BindArrayGetSize(st);
    iStmtActionRes = OCI_Execute(st);
    iAffectedRows = OCI_GetAffectedRows(st);
    En cas d'erreur je pensais naïvement que le code suivant fonctionnait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    if (FALSE == iStatement) {
    OCI_Error*	pErr = OCI_GetBatchError(st);
    	while ( NULL != pErr )
    	{
    		unsigned int iRowIndex = OCI_ErrorGetRow(pErr);
    		if ( 0 > iRowIndex )
    			ERREUR(thread) << "Error at row : <" << OCI_ErrorGetRow(pErr) << "> : <" << OCI_ErrorGetString(pErr) << ">" << print ;
    		else
    			ERREUR(thread) << "Error not related to array DML: " << OCI_ErrorGetString(pErr) << print ;
     
    		// Get next error
    		pErr = OCI_GetBatchError(st);
             }
    Dès le premier appel à OCI_GetBatchError le programme plante brutalement... J'en conclus que je ne dois pas faire quelque chose que je devrais. Probablement une initialisation... Mais à quel moment?

  2. #2
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Par défaut
    Salut,

    c'est un bug présent dans la 3.5.0. La fonction OCI_GetBatchError() ne vérifiait pas la validité d'un pointeur interne et donc un segfault survenait si aucune erreur DML n'était générée par OCI.

    Cela a été corrigé dans la 3.7.0 (cf . changelog)

    Récupère la dernière version 3.8.1
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

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

Discussions similaires

  1. [FB] Gestion des erreurs et application francophone
    Par Benjamin GAGNEUX dans le forum Installation
    Réponses: 10
    Dernier message: 20/05/2006, 14h54
  2. [struts][Datasource]Gestion des erreurs
    Par GreenJay dans le forum Struts 1
    Réponses: 8
    Dernier message: 15/09/2004, 16h51
  3. [VB6] Gestion des erreurs dans une dll
    Par zimba-tm dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 02/08/2004, 11h20
  4. [XSLT]Est ce qu'il y'a la gestion des erreur en xslt ?
    Par miloud dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 04/02/2004, 17h19
  5. [LG]gestion des erreurs
    Par frontin dans le forum Langage
    Réponses: 3
    Dernier message: 29/11/2003, 22h41

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