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 Firebird Discussion :

Requete recursive et CTE


Sujet :

SQL Firebird

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Homme Profil pro
    Ingenieur de recherche - Ecologue
    Inscrit en
    Juin 2003
    Messages
    1 157
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingenieur de recherche - Ecologue

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 157
    Par défaut Requete recursive et CTE
    Bonjour a tous

    depuis la version 2.1, firebird, il est possible d'utiliser les CTE, notamment pour faire des requetes recursives.


    j'essaye, mes j'eprouve qq difficultes. par exemples je n'arrive pas a faire apparaitre les resultats !
    le mot-cle SUSPEND

    Alors comment fait t'on pour faire apparaitre les resultats ?

    voici ma table test et procedure test

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE A_TEST (
        ID_PERE    INTEGER,
        ID_ENFANT  INTEGER NOT NULL
    );
    les donnees

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    INSERT INTO A_TEST (ID_PERE, ID_ENFANT) VALUES (NULL, 1);
    INSERT INTO A_TEST (ID_PERE, ID_ENFANT) VALUES (1, 2);
    INSERT INTO A_TEST (ID_PERE, ID_ENFANT) VALUES (2, 3);
    INSERT INTO A_TEST (ID_PERE, ID_ENFANT) VALUES (1, 4);
    INSERT INTO A_TEST (ID_PERE, ID_ENFANT) VALUES (2, 5);
    et voici la procedure

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    CREATE PROCEDURE AAAA_TEST (
        Enfant INTEGER)
    RETURNS (
        Id_enfant INTEGER,
        Id_pere INTEGER)
    AS
    begin
     
      with recursive test (t_Fils, T_Pere)
      as
           (SELECT
                A_test.Id_enfant,
                A_test.Id_pere
            FROM
                A_test
           where A_test.Id_pere IS Null
            UNION ALL
            SELECT Bis.Id_enfant,
                Bis.Id_pere
            FROM
                A_test BIS
                    INNER JOIN Test Ter ON (Ter.T_Pere = Bis.Id_enfant)
     )
     
     Select t_Fils, t_Pere from test
     where test.t_Fils = :enfant
      INTO
         :Id_enfant ,
         :Id_pere
           ;
     
     
    end
    Et je suis sur que la reponse doit etre triaviale

    a+

    olivier

  2. #2
    Membre Expert
    Homme Profil pro
    Ingenieur de recherche - Ecologue
    Inscrit en
    Juin 2003
    Messages
    1 157
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingenieur de recherche - Ecologue

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 157
    Par défaut
    personne n'a d'idee ?

    ou la question est par trop trivale !

    a+
    olivier

  3. #3
    Membre Expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Par défaut
    oui trivial, la requete CTE est comme une autre requete
    Mettre une boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      FOR 
      INTO 
      DO BEGIN
           SUSPEND;
         END

  4. #4
    Membre Expert
    Homme Profil pro
    Ingenieur de recherche - Ecologue
    Inscrit en
    Juin 2003
    Messages
    1 157
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingenieur de recherche - Ecologue

    Informations forums :
    Inscription : Juin 2003
    Messages : 1 157
    Par défaut
    Imbecile je suis, je n'avais pas pense inclure dans la boucle FOR INTO
    la TOTALITE de la requete CTE...




    sorry

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/09/2007, 11h14
  2. Requete recursive avec WITH
    Par Kuroro dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 06/09/2007, 23h05
  3. Requete recursive et MySQL
    Par TangoZoulou dans le forum Requêtes
    Réponses: 3
    Dernier message: 13/07/2007, 15h36
  4. Requete recursive : recupérer enreg. selon plusieurs dates
    Par kinder_bueno dans le forum Langage SQL
    Réponses: 3
    Dernier message: 08/03/2007, 08h35
  5. requete recursive ( connect prior by)
    Par smedini dans le forum Oracle
    Réponses: 4
    Dernier message: 08/11/2005, 17h16

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