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

UPDATE avec multiple rows


Sujet :

SQL Oracle

  1. #1
    Membre habitué
    Inscrit en
    Septembre 2002
    Messages
    233
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 233
    Points : 131
    Points
    131
    Par défaut UPDATE avec multiple rows
    Bonjour,

    J'ai une question a propos de la requete de type update, je souhaite mettre à jour une table via un sous SELECT, cependant dans certains cas le SELECT me retourne plusieurs lignes ce qui créée une erreur SQL lors de la mise à jour. J'ai essayé la technique du rownum comme indiqué dans la FAQ mais dans ce cas, la sous - sous requête ne voit plus la table à mettre à jour :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
          UPDATE tb_eval SET reponse = (
                                                  SELECT reponse 
                                                  FROM tb_repondu
                                                  WHERE tb_repondu.questionnaire = tb_eval.questionnaire
                                                  AND ...
                                                  );
    Erreur Multiple rows


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
          UPDATE tb_eval SET reponse = (
                                                   SELECT reponse FROM 
                                                   (
                                                            SELECT *
                                                            FROM tb_repondu
                                                            WHERE tb_repondu.questionnaire = tb_eval.questionnaire
                                                            AND ...
                                                            ORDER BY date DESC
                                                  )    WHERE rownum < 2   );
    tb_eval plus reconnue dans la sous sous requete !

    Il y a t'il une parade ?

    Merci

  2. #2
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    UPDATE tb_eval SET reponse = (
                                                   SELECT max(reponse) keep (dense rank first order by date desc)
                                                            FROM tb_repondu
                                                            WHERE tb_repondu.questionnaire = tb_eval.questionnaire
                                                            AND ...
                                                            )
    ou à l'ancienne (mais beaucoup moins bon)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    = (select SUBSTR(MAX(TO_CHAR(date, 'RRRRMMDDHH24MISS')||reponse),15)
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/01/2011, 15h14
  2. [AC-2003] UPDATE avec de multiples colonnes
    Par jimay dans le forum Requêtes et SQL.
    Réponses: 0
    Dernier message: 14/05/2009, 10h08
  3. Faire un update avec une ss requete renvoyant plusieur row
    Par djodjo dans le forum Langage SQL
    Réponses: 6
    Dernier message: 02/09/2005, 15h51
  4. Réponses: 3
    Dernier message: 25/01/2005, 12h31
  5. Pb Update avec chaine de caractere
    Par JuJu° dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/05/2003, 15h58

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