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 :

update renvoyant pusieurs lignes


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre régulier
    Inscrit en
    Décembre 2006
    Messages
    243
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 243
    Points : 120
    Points
    120
    Par défaut update renvoyant pusieurs lignes
    Bonjour,

    Je souhaite mettre à jour un champ d'une table à l'aide des valeurs d'un champ d'une autre table grâce à une jointure.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update cat_regards set z_tamp = (select b.z from cat_regards as a, tampons_a as b where a.z_tamp = 0 and b.z <> 0 and a.num_reg = b.idcateg)
    Cependant j'obtiens une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ERROR: more than one row returned by a subquery used as an expression
    État SQL :21000
    Faut-il utiliser plpgsql ?

    Merci

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    178
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 178
    Points : 220
    Points
    220
    Par défaut
    Bonjour,

    Non c'est juste que dans certains cas votre jointure renvoie plus d'une ligne, alors dans ce cas laquelle mettre dans le champ à modifier ? Soit il manque une condition pour que la jointure soit correcte, soit vous récupérez plusieurs fois la même valeur et un SELECT DISTINCT corrigera le problème.

  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
    Deux remarques
    Si la table à modifier (tampons_a) est répétée dans la sous-requête comme c'est le cas ici, l'interpréteur sql ne fera aucune corrélation entre les deux. Pour avoir corrélation il faut se référer à la table à modifier sans répéter son nom.
    D'autre part, le where a.z_tamp=0 qui limite les lignes à modifier doit probablement être en dehors de la ss-requête

    A mon avis ce qui est cherché ressemblerait plus à ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    UPDATE cat_regards AS a SET z_tamp=b.z FROM
       (SELECT z,idcateg FROM tampons_a WHERE z <> 0 ) b
     WHERE a.z_tamp = 0  and a.num_reg=b.idcateg

  4. #4
    Membre régulier
    Inscrit en
    Décembre 2006
    Messages
    243
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 243
    Points : 120
    Points
    120
    Par défaut
    Bonjour,

    C'est bon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE cat_regards a SET z_tamp = foo.z
    FROM (select z, idcateg from tampons_a b WHERE z <> 0) as foo
    where a.z_tamp = 0 AND foo.z <> 0 AND a.num_reg = foo.idcateg
    Merci bien.

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

Discussions similaires

  1. Update de la ligne X
    Par ekinoxe dans le forum ASP
    Réponses: 5
    Dernier message: 20/01/2006, 12h58
  2. [8i] Update sur une ligne invalide
    Par Apsolu dans le forum Oracle
    Réponses: 3
    Dernier message: 09/01/2006, 22h06
  3. Trigger inserant une ligne auto en cas d'UPDATE de 0 lign
    Par bbshadoks dans le forum Développement
    Réponses: 4
    Dernier message: 04/05/2005, 14h00
  4. [C#] DataGrid : Update d'une ligne
    Par Joad dans le forum ASP.NET
    Réponses: 12
    Dernier message: 29/04/2005, 13h14
  5. UPdate / Nb de lignes modifiées
    Par Thomad dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 04/09/2003, 12h52

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