Précédent   Forum des professionnels en informatique > Bases de données > Oracle > Interfaces de programmation
Interfaces de programmation Forum d'entraide sur l'utilisation des API Oracle : Pré-compilateurs, OCI, OCCI, etc.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 11/09/2006, 10h24   #1
Membre du Club
 
Avatar de Bahan
 
Inscription : avril 2006
Messages : 147
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : avril 2006
Messages : 147
Points : 54
Points : 54
Envoyer un message via MSN à Bahan
Par défaut [PRO*C] Recuperer le codeRetour d'une fonction SQL

Bonjour à toutes et à tous.

Ayant développé quelques petites fonctions en PL/SQL, j'aimerais maintenant récupérer le retour de certaines fonctions dans une variable que je
retournerai dans mon programme en C et ce pour me fournir diverses
informations (sortie ok, nok, pas de nouvelles données à traiter etc...).

Cependant, voila un peu ce que donne mon code PRO*C :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
EXEC SQL INCLUDE SQLCA;

int MaFonctionAppeleeDansMonCodeC
    ( int iMonParametre1EnC
    , int iMonParametre2EnC)
{
    EXEC SQL WHENEVER SQLERROR GOTO ERR_APPEL ;
    EXEC SQL EXECUTE 
    DECLARE
        vCrFonction    NUMBER;
        vMonParametre1    NUMBER;
        vMonParametre2    NUMBER;

    BEGIN
        vMonParametre1 := :iMonParametre1EnC;
        vMonParametre2 := :iMonParametre2EnC;

        vCrFonction := MonPackageSql.MaFonctionSql(MonParametre1, 
MonParametre2);

    END;

    END-EXEC;
    return(je voudrais retourner vCrFonction);

    ERR_APPEL:
    return(-1);
}
En fait, je sais que pour utiliser les variables C dans mon code SQL je dois mettre :. Cependant, pour faire l'inverse, i.e. utiliser une variable SQL dans mon code C, je ne sais pas vraiment comment procéder.

Merci d'avance pour vos réponses.

Bahan
Bahan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/09/2006, 10h28   #2
Membre Expert
 
Avatar de zooro
 
Inscription : avril 2006
Messages : 922
Détails du profil
Informations personnelles :
Âge : 33
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : avril 2006
Messages : 922
Points : 1 149
Points : 1 149
Salut,
As-tu essayé de déclarer une variable int avant le bloc Pro*C, et de lui affecter ensuite la valeur de vCrFonction ? Voire de déclarer directement vCrFonction comme int ?
__________________
[alkama] quelqu'un est allé voir la guerre des mondes?
[@Chrisman] j'espère pour spielberg
--- bashfr.org
zooro est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/09/2006, 16h06   #3
Membre du Club
 
Avatar de Bahan
 
Inscription : avril 2006
Messages : 147
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : avril 2006
Messages : 147
Points : 54
Points : 54
Envoyer un message via MSN à Bahan
Je vous remercie beaucoup de votre réponse.
Ca marche .
Bahan
Bahan est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 16h47.


 
 
 
 
Partenaires

Hébergement Web