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

PL/SQL Oracle Discussion :

[ADO.NET] Comment récupérer la valeur de retour d'une fonction PL/SQL ? [Fait]


Sujet :

PL/SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    123
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 123
    Points : 53
    Points
    53
    Par défaut [ADO.NET] Comment récupérer la valeur de retour d'une fonction PL/SQL ?
    Bonjour, j'ai écrit une fonction PL/SQL, elle est donc stockée dans ma base de données Oracle 10g XE. Voici son code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    create or replace
    FUNCTION FCT_IfActExists
    (IdPerso IN PERSONNE.ID_PERSONNE%Type)
    RETURN INTEGER
    IS
    NbResult INTEGER;
    BEGIN
    SELECT COUNT(*) INTO NbResult FROM ACTEUR WHERE ID_PERSONNE=IdPerso;
    IF NbResult > 0 THEN
    RETURN (1);
    ELSE RETURN (0);
    END IF;
    END;
    Je veux exécuter cette fonction à partir de mon application C# (Winforms) et en récupérer la valeur de retour mais je ne sais pas du tout comment faire !

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    pour exécuter une fonction pl/sql depuis une application, tu utilises un block pl/sql en lieu et place d'une requête.

    Par exemple, pour une requête tu ferais quelque chose du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    stmt.execute("select ... from ...");
    Pour exécuter du pl/sql :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    stmt.execute("begin ma_fonction(...); end;");
    Pour la liaison de données, voit la doc ton driver.
    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

  3. #3
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    123
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 123
    Points : 53
    Points
    53
    Par défaut
    Pour l'exécution, je sais ce qu'il faut faire, c'est pour récupérer la valeur de retour que je sais pas, et je trouve pas d'exemple ou de tuto qui peut m'aider.
    Désolé ta réponse ne m'aide pas

  4. #4
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    123
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 123
    Points : 53
    Points
    53
    Par défaut
    J'avais commencé à faire quelque chose de ce genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    string req_NbAct = "BEGIN :NbActeur:=FCT_IFACTEXISTS(" + IdPerso + "); END;";
    OracleCommand cmd_NbAct = new OracleCommand(req_NbAct, OConnexion);
    cmd_NbAct.Parameters.Add("NbActeur", OracleDbType.Int32, ParameterDirection.Output);
    int NbActeur = (int)cmd_NbAct.ExecuteScalar();
    Mais ca ne fonctionne pas

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    Une petite recherche sur google ou sur le forum t'aurait peut être aidé ...

    @google : Accessing Oracle 9i Stored Procedures Using ADO.NET
    @forum : [3.5 + ADO.net] Récup Output Parameter
    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

  6. #6
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    123
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 123
    Points : 53
    Points
    53
    Par défaut
    J'ai cherché, mais pas en anglais

    Merci pour les liens

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 22/02/2013, 15h24
  2. Réponses: 7
    Dernier message: 28/10/2010, 21h55
  3. comment récupérer la valeur de retour d'une fonction
    Par sebac dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 26/02/2010, 09h28
  4. Récupérer la valeur de retour d'une fonction JS
    Par gobgob dans le forum Bibliothèques et frameworks
    Réponses: 12
    Dernier message: 17/02/2009, 18h22
  5. Réponses: 4
    Dernier message: 19/01/2009, 11h12

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