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 :

[D2010] Comment utiliser la même session Oracle dans une DLL avec ODAC ?


Sujet :

Bases de données Delphi

  1. #1
    Expert éminent
    Avatar de Lung
    Profil pro
    Analyste-programmeur
    Inscrit en
    Mai 2002
    Messages
    2 664
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste-programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 664
    Points : 6 965
    Points
    6 965
    Par défaut [D2010] Comment utiliser la même session Oracle dans une DLL avec ODAC ?
    Je suis en train de convertir un exe D6 et une DLL (D6 aussi) en D2010.
    En même temps, je passe du BDE à ODAC.

    Pour l'exe, pas de problème.
    Pour la DLL, je ne sais pas comment faire pour utiliser la même session Oracle dans la DLL que dans l'exe.
    - Avec le BDE, je passais @Session dans un paramètre pSession: Pointer, et ça fonctionnait bien dans la DLL.
    - Avec ODAC, j'ai essayé de passer le OraSession dans un paramètre de type Pointer et aussi de type TOraSession:
    Ca semble fonctionner. En pas-à-pas, je vois bien les propriétés du OraSession qui semblent bien renseignées (dans la DLL).
    Je peux exécuter une ou deux requêtes simples, mais à partir de la troisième (aléatoirement), dès que le SQL devient un peu compliqué (paramètre oracle, sous-requête avec in, ...), j'obtiens une violation d'accès, et je n'ai plus qu'à tout tuer, si je ne veux pas planter Delphi avec.

    Comment faire ?
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai. ___ Écrivez dans un français correct !!

    C++Builder 5 - Delphi 6#2 Entreprise - Delphi 2007 Entreprise - Delphi 2010 Architecte - Delphi XE Entreprise - Delphi XE7 Entreprise - Delphi 10 Entreprise - Delphi 10.3.2 Entreprise - Delphi 10.4.2 Entreprise - Delphi 11.1 Entreprise
    OpenGL 2.1 - Oracle 10g - Paradox - Interbase (XE) - PostgreSQL (15.4)

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 452
    Points : 24 863
    Points
    24 863
    Par défaut
    FastShareMem ou BorlndMM doit être nécessaire pour l'échange d'objet entre EXE et DLL
    Pense que la DLL ne doit pas libérer un pointeur alloué par l'EXE et vice-versa !
    ShareMem permet de simplifier cela !

    tu peux aussi déporter l'ensemble de la DB dans une DLL qui sera utilisé par l'EXE et l'autre DLL, ne pas partager d'objet mais des Interfaces qui seront toujours exécutés dans l'espace mémoire de la DLL DB
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Expert éminent
    Avatar de Lung
    Profil pro
    Analyste-programmeur
    Inscrit en
    Mai 2002
    Messages
    2 664
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste-programmeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 664
    Points : 6 965
    Points
    6 965
    Par défaut
    Victoire !
    J'ai un collègue qui a trouvé la solution.
    Il faut bien passer le TOraSession de l'exe à la DLL.
    Mais ensuite, dans la DLL, il faut créer un autre OraSession (interne à la DLL) et utiliser OraSessionDLL.AssignConnect(ParametreOraSession);
    pour lui transmettre tout ce qu'il faut.
    Bien sûr, toutes les OraQuery doivent être reliées à l'OraSession de la DLL.
    Chose qui semble importante, en sortie de la DLL, il faut faire un OraSessionDLL.AssignConnect(nil);

    Citation Envoyé par ShaiLeTroll Voir le message
    FastShareMem ou BorlndMM doit être nécessaire pour l'échange d'objet entre EXE et DLL
    Je ne les ai jamais utilisés. Ca aide à quel niveau ?

    Citation Envoyé par ShaiLeTroll Voir le message
    Pense que la DLL ne doit pas libérer un pointeur alloué par l'EXE et vice-versa !
    Pour ça, pas de problème. J'essais de bien y faire attention.

    Citation Envoyé par ShaiLeTroll Voir le message
    tu peux aussi déporter l'ensemble de la DB dans une DLL qui sera utilisé par l'EXE
    C'est pas le but; mais effectivement, c'est une façon de contourner le problème.

    Citation Envoyé par ShaiLeTroll Voir le message
    ne pas partager d'objet mais des Interfaces qui seront toujours exécutés dans l'espace mémoire de la DLL DB
    Je ne connais pas les interfaces.
    L'urgent est fait, l'impossible est en cours, pour les miracles prévoir un délai. ___ Écrivez dans un français correct !!

    C++Builder 5 - Delphi 6#2 Entreprise - Delphi 2007 Entreprise - Delphi 2010 Architecte - Delphi XE Entreprise - Delphi XE7 Entreprise - Delphi 10 Entreprise - Delphi 10.3.2 Entreprise - Delphi 10.4.2 Entreprise - Delphi 11.1 Entreprise
    OpenGL 2.1 - Oracle 10g - Paradox - Interbase (XE) - PostgreSQL (15.4)

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 29/08/2014, 16h26
  2. Comment utiliser un bundle en JAVAEE dans une simple page XHTML
    Par geforce dans le forum Développement Web en Java
    Réponses: 1
    Dernier message: 22/01/2013, 13h06
  3. Réponses: 0
    Dernier message: 26/05/2010, 22h57
  4. Réponses: 5
    Dernier message: 27/08/2006, 14h24
  5. Réponses: 4
    Dernier message: 03/03/2004, 11h04

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