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

PostgreSQL Discussion :

combiner "Cursor" et "WITH RECURSIVE" dans une procédure stockée


Sujet :

PostgreSQL

  1. #1
    Membre habitué Avatar de archer
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    338
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Mai 2007
    Messages : 338
    Points : 180
    Points
    180
    Par défaut combiner "Cursor" et "WITH RECURSIVE" dans une procédure stockée
    Bonjour,

    Je suis entrain d'écrire une procédure stockée qui doit tout d'abord lancer une requête hiérarchique sur une table puis faire des traitements. Pour ce faire, j'ai utilisé WITH RECURSIVE en créant une nouvelle table "tree", maintenant j'ai besoin de créer un curseur qui va lire le contenu de cette table pour la parcourir puis la traiter.
    Le problème c'est au niveau de la déclaration. Si je mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    DECLARE
    curs refcursor;
    WITH RECURSIVE tree(.....)
    OPEN curs for select ... from tree;
    il ne l'accepte pas.
    Y a-t-il d'autres alternatives qui me permettent le parcours en avant et en arrière de la table tree?
    Merci d'avance.
    rien pour l'instant

  2. #2
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Qu'entendez vous par traiter?

    Pourquoi utiliser un curseur qui est procédurale et contre-performant à souhait?
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    Le WITH fait partie intégrante de la requête, il faut écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    OPEN curs FOR WITH... SELECT ... FROM tree;

Discussions similaires

  1. Réponses: 0
    Dernier message: 09/04/2014, 10h06
  2. Dans une procédure, cursor ou ref cursor ?
    Par tcr54 dans le forum PL/SQL
    Réponses: 1
    Dernier message: 28/08/2011, 15h09
  3. Réponses: 2
    Dernier message: 18/09/2007, 11h14
  4. Est il possible de faire un cursor sur une procédure stocké ?
    Par berceker united dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 03/09/2007, 16h47
  5. Quote dans une requete...
    Par Isildur dans le forum Langage SQL
    Réponses: 6
    Dernier message: 20/06/2006, 10h57

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