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

Requêtes PostgreSQL Discussion :

Incrémentation variable fonction update


Sujet :

Requêtes PostgreSQL

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2013
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2013
    Messages : 40
    Points : 29
    Points
    29
    Par défaut Incrémentation variable fonction update
    Bonjour à tous,

    J'ai besoins de faire un update sur la colonne d'une table suivant une année pour insérer un nombre qui doit respecter une suite logique (n+1)

    J'étais parti sur ceci :

    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
    CREATE OR REPLACE FUNCTION num(_p1 integer, _p2 integer) RETURNS void AS $func$
    DECLARE
        mon_cursor CURSOR IS
        SELECT * FROM  table1 JOIN table2 USING (colA) 
        WHERE table2.colB = _p1 AND table2.colC = _p2;
        iterator INTEGER := 0;
    BEGIN
      FOR C IN mon_cursor
      LOOP
        iterator :=iterator +1;
        UPDATE table1 SET colD = iterator 
        WHERE table1.colD = 0;
      END LOOP;
    END;
    $func$ LANGUAGE plpgsql;
    Mon problème étant que ma variable iterator ne s'incrémente pas (colD toujours = 1) et que je ne comprends pas pourquoi. (J'ai essayé d'autre solution mais le problème reste identique).

  2. #2
    Membre expert
    Avatar de alassanediakite
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2006
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2006
    Messages : 1 599
    Points : 3 590
    Points
    3 590
    Billets dans le blog
    8
    Par défaut
    Salut
    Il y a assez de problèmes dans votre code.
    • Je suppose que le UPDATE de la table doit être lié au curseur, ce qui n'est pas le cas dans votre code! Ce sont les (ou la) même lignes que sont modifiées avec la même valeur de "iterator" (qui change!!! sauf si votre curseur ne contient qu'une ligne).
    • Votre variable "C" n'est pas déclarée!

    Par ailleurs votre but manque est manque de plus de précision.
    Donnez un exemple complet pour la compréhension du problème: le contenu de la table au départ, une description des paramètres de la fonction, le contenu de la table à la fin de l'exécution.
    @+
    Le monde est trop bien programmé pour être l’œuvre du hasard…
    Mon produit pour la gestion d'école: www.logicoles.com

Discussions similaires

  1. [XL-2003] ListBox incrémentée en fonction d'une variable i
    Par maud.33500 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 11/07/2011, 07h45
  2. problème incrémentation en fonction d'une variable
    Par polo42 dans le forum VBA Access
    Réponses: 10
    Dernier message: 07/08/2007, 16h13
  3. astuce avec fonction update
    Par cubepiege dans le forum Langage SQL
    Réponses: 2
    Dernier message: 08/11/2005, 10h54
  4. Incrémentation Variable
    Par Boujou dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 21/04/2005, 11h28
  5. [Update TQuery]Lenteur de la fonction Update
    Par Eric SAULNIER dans le forum Bases de données
    Réponses: 2
    Dernier message: 11/05/2004, 01h29

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