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

SQL Oracle Discussion :

procédure stockée : SELECT


Sujet :

SQL Oracle

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut procédure stockée : SELECT
    Bonjour,

    j'ai regarder un peu partout sur le net, mais rien ne me convient vraiment.

    Quelqu'un pourrait me dire comment fait-on pour renvoyer des résultats (à l'aide d'un SELECT) depuis une procédure stockée?

    Je sais qu'il faut utiliser des curseurs mais justement je ne sais pas le faire.

    Si vous pouviez me donner la structure d'une requete SELECT dans une procédure stockée (requete très simple)

    merci d'avance

  2. #2
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Voici un exemple tout seul d'une fonction renvoyant un ref cursor :
    http://www.developpez.net/forums/sho...57&postcount=2

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut
    non ca ne fonctionne pas, c'est pas du pl/sql oracle pur ca.

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut
    moi j'avais ceci mais cette procédure ne renvoie pas de résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    CREATE OR REPLACE
    PROCEDURE COURTDISPO AS
    BEGIN
    DECLARE
    court COURTS.CODE%type;
      CURSOR curseur 
          IS SELECT code 
             FROM courts;
    BEGIN
        OPEN curseur;
         LOOP
           FETCH curseur INTO court;
           EXIT WHEN curseur%NOTFOUND;
        END LOOP;
    END;
    END COURTDISPO;
    alors que toute seule, la requete select from me renvoie bien les résultats attendus

  5. #5
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Citation Envoyé par marcusien
    non ca ne fonctionne pas, c'est pas du pl/sql oracle pur ca.
    Je ne sais pas ce que c'est alors ????
    Il y a juste l'exécution de la fonction qui n'est pas du PL pur, mais avec un minimum d'effort et de recherche sur le forum tu devrais pouvoir t'en sortir, non ?

  6. #6
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    J'ai un doute sur ta question initiale : tu veux une procédure qui renvoie un curseur ou tu veux juste utiliser un curseur dans une procédure ?

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut
    non, ce que je veux c'est une procédure stockée qui me renvoie le résultat d'une requête SELECT FROM WHERE.

    Mais en Oracle apparemment il faut utiliser des curseurs etc.

    En SQL server il suffit juste de faire un SELECT et on peut lire le résultat sans soucis dans une application a l'aide d'un SQL Data reader.

  8. #8
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Dans ce cas adapte à ton besoin la fonction que je t'ai proposée.

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut
    J'ai bien essayer mais je n'y arrive pas.

    Et je suis très pressé par le temps et j'ai beaucoup d'autres projets à coté, je n'ai malheureusement pas le temps de me pencher sur des problèmes de la sorte

    Mais tu as vu ma requête en haut, pourrait tu me dire ce qui ne va pas?

  10. #10
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    1 024
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 1 024
    Points : 1 294
    Points
    1 294
    Par défaut
    Il y a une différence fondamentale entre ORACLE et SQL-Serveur sur ce point. Sur SQL-Serveur, ça a un sens de faire un select dans une procédure stockée, en oracle, non.

    Car si sur les 2 bases, le terme de "procédure stockée" est employé, dans les fait, ce n'est pas la même chose.

    Oracle fait une stricte séparation entre les traitement des données qui se fait du coté base(procédure stockée) et l'affichage des données qui se fait toujours par une application cliente (SQL*PLUS, java-JDBC, VB-ODBC etc...)

    Effectivement, si tu veux afficher le resultat d'un select, aucune procédure stockée ne pourra le faire, mais une procédure pourra préparer le boulot à une application cliente en lui renvoyant un curseur. Charge à l'application client de savoir lire et afficher ce curseur.

    Tu trouveras des exemples sur ce site, par exemple, regarde le dernier message de ce post: LA

  11. #11
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Qu'est-ce que tu as fait ? Qu'est-ce qui ne fonctionnait pas ?

    Le principe est simple tu crées un ref cursor que tu renvois en paramètre out cela peut être une requête dynamique comme dans l'exemple proposé ou une requête fixe comme cela (ce qui revient au même):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    create or replace procedure p1 (rc out sys_refcursor) is
    begin
      open rc for select a, b from table1;
    end;
    /
    Et pour l'exécuter en PL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    declare
      rc sys_refcursor;
      a varchar2(80);
      b varchar2(80);
    begin
      p1(rc);
      fetch rc into a, b;
    end;
    /

  12. #12
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    351
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Côte d'Or (Bourgogne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 351
    Points : 321
    Points
    321
    Par défaut
    moi les refcursor il ne veut meme pas m'en déclarer, il me dit que ca n'existe pas.
    Je suis en oracle 10g express, mais normalement il n'y a pas de soucis.
    je peux declarer un cursor, mais pas de ref cursor

Discussions similaires

  1. Réponses: 1
    Dernier message: 03/09/2009, 12h39
  2. [Procédure stockée] Select * into
    Par Gregory.M dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 17/03/2009, 14h18
  3. Procédure stockée, Select + Insert
    Par Gregory.M dans le forum Langage SQL
    Réponses: 5
    Dernier message: 09/12/2008, 11h03
  4. Réponses: 3
    Dernier message: 21/01/2008, 12h03
  5. Procédure stockée - Select
    Par lecitoyen dans le forum Langage SQL
    Réponses: 5
    Dernier message: 24/10/2007, 20h29

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