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 :

plpgsql et boucles


Sujet :

PostgreSQL

  1. #1
    Nouveau candidat au Club
    Inscrit en
    Novembre 2004
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Novembre 2004
    Messages : 1
    Par défaut plpgsql et boucles
    voila je suis entrain de me battre avec les fonctions en plpgsql

    je dois parcourir tout les résultats d'une requête pour pouvoir les déplacer dans une autre table

    j'ai le code suivant :

    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
     
    iDROP FUNCTION clean_mesure();
    CREATE OR REPLACE FUNCTION clean_mesure() RETURNS void AS '
            DECLARE
                    tmp RECORD;
                    res RECORD;
            BEGIN
                    FOR valeurs IN SELECT * FROM mesure WHERE EXTRACT(day FROM current_timestamp-date)<=1 LOOP
                            SELECT INTO res count(carte) FROM archive WHERE carte=valeurs.carte AND date=date(valeurs.date);
                            IF res.count = 0 THEN
                                    INSERT INTO acrhive VALUES (date(tmp.date),valeurs.carte,tmp.valeurs);
                            ELSE
                                    UPDATE archive SET valeurs[1]=valeurs[1]+tmp.valeurs[1],valeurs[2]=valeurs[2]+tmp.valeurs[2],
                                                       valeurs[3]=valeurs[3]+tmp.mesures[3],valeurs[4]=valeurs[4]+tmp.mesures[4],
                                                       valeurs[5]=valeurs[5]+tmp.mesures[5],valeurs[6]=valeurs[6]+tmp.mesures[6]
                                                       WHERE carte=valeurs.carte AND date=date(valeurs.date);
                            END IF;
     
                    END LOOP;
                    RETURN NULL;
            END;'
            LANGUAGE 'plpgsql';
    j'ai systématiquement le message d'erreur :

    ERROR: missing ".." at end of SQL expression


    je pense que cela vient de la boucle mais je vois pas trop pourquoi car la plus part des exemples la méthode et celle que j'ai utilisé

  2. #2
    Membre Expert
    Avatar de hpalpha
    Inscrit en
    Mars 2002
    Messages
    769
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 769
    Par défaut
    Salut,

    en fait c'est parce que tu n'as pas declarer ta variable valeurs

    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
    DROP FUNCTION clean_mesure(); 
    CREATE OR REPLACE FUNCTION clean_mesure() RETURNS void AS ' 
            DECLARE 
                    tmp RECORD; 
                    res RECORD; 
                   valeurs RECORD; 
                    -- ou encore
                    -- valeurs mesure%ROWTYPE;
            BEGIN 
                    FOR valeurs IN SELECT * FROM mesure WHERE EXTRACT(day FROM current_timestamp-date)<=1 LOOP 
                            SELECT INTO res count(carte) FROM archive WHERE carte=valeurs.carte AND date=date(valeurs.date); 
                            IF res.count = 0 THEN 
                                    INSERT INTO acrhive VALUES (date(tmp.date),valeurs.carte,tmp.valeurs); 
                            ELSE 
                                    UPDATE archive SET valeurs[1]=valeurs[1]+tmp.valeurs[1],valeurs[2]=valeurs[2]+tmp.valeurs[2], 
                                                       valeurs[3]=valeurs[3]+tmp.mesures[3],valeurs[4]=valeurs[4]+tmp.mesures[4], 
                                                       valeurs[5]=valeurs[5]+tmp.mesures[5],valeurs[6]=valeurs[6]+tmp.mesures[6] 
                                                       WHERE carte=valeurs.carte AND date=date(valeurs.date); 
                            END IF; 
     
                    END LOOP; 
                    RETURN NULL; 
            END;' 
            LANGUAGE 'plpgsql';

Discussions similaires

  1. [XSLT] Faire une boucle sur une variable [i]
    Par PoT_de_NuTeLLa dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 07/06/2010, 12h45
  2. Curseur et Boucle FOR - PLPGSQL
    Par dino86 dans le forum PostgreSQL
    Réponses: 0
    Dernier message: 14/04/2008, 14h06
  3. PLPGSQL : Mon trigger boucle t'il sur lui même ?
    Par htristra dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 08/09/2007, 19h27
  4. Sortir d'un progamme qui boucle ou qui refresh
    Par mikevador02 dans le forum C
    Réponses: 12
    Dernier message: 14/12/2002, 09h38
  5. Réponses: 2
    Dernier message: 29/05/2002, 20h43

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