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

Langage SQL Discussion :

Requete Mise A Jour UPDATE


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 5
    Par défaut Requete Mise A Jour UPDATE
    Bonjour a tous ,
    Novice dans le monde du SQL, j'aurais souhaité quelques renseignements :

    Je dispose d'une table LOCATION ou l 'on peut retrouver le LIBELLE du materiel LOUE et le prix de location journalier ( PLOCJ ) de ce materiel. Je souhaiterais augmenter le PLOCJ de 5% pour les materiels de type ( LIBELLE ) JARDINAGE et de 10 % pour les materiels de type ( LIBELLE ) MENUISERIE . Le tout dans une même requête SQL . Il me semble que l'on peut le faire avec une requete UPDATE mais qu'il existe une autre facon de faire ???

    Merci de votre aide precieuse !!

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Par défaut
    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
    10g SOC5> SELECT *
      2  FROM LOCATION;
     
    LIBELLE                                                 PLOCJ
    -------------------------------------------------- ----------
    JARDINAGE                                                  12
    JARDINAGE                                                  27
    MENUISERIE                                                 36
    MENUISERIE                                                 10
    MENUISERIE                                               1200
     
    5 ligne(s) sélectionnée(s).
     
    10g SOC5> 
    10g SOC5> UPDATE LOCATION
      2  SET PLOCJ = CASE WHEN LIBELLE = 'JARDINAGE' THEN PLOCJ * 105/100
      3                   WHEN LIBELLE = 'MENUISERIE' THEN PLOCJ * 110/100 END;
     
    5 ligne(s) mise(s) à jour.
     
    10g SOC5> 
    10g SOC5> SELECT *
      2  FROM LOCATION;
     
    LIBELLE                                                 PLOCJ
    -------------------------------------------------- ----------
    JARDINAGE                                                  13
    JARDINAGE                                                  28
    MENUISERIE                                                 40
    MENUISERIE                                                 11
    MENUISERIE                                               1320
     
    5 ligne(s) sélectionnée(s).

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 5
    Par défaut
    j avais pas pensé au CASE !!!!

    Merci pour cette réponse super rapide !!!

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Par défaut
    Vous avez d'autres alternatives au CASE qui ne sont pas forcément conforme vis-à-vis de la norme SQL mais si votre SGBD - que vous avez oublié de préciser (Cf. les règles du forum) - supporte cette construction alors autant l'utiliser.
    Sous Oracle, j'utiliserais sinon DECODE.

    Enfin, merci de cliquer sur le bouton "Résolu" si vous avez trouvé une solution à votre problème.

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 5
    Par défaut
    désolé j'ai en effet omis de dire que je fonctionne sous oracle .

    Quel serait la syntaxe avec le fameux DECODE ?

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Avril 2005
    Messages
    1 673
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 673
    Par défaut
    Citation Envoyé par Teddy63
    Quel serait la syntaxe avec le fameux DECODE ?
    Cf. la doc Oracle mais quelque chose comme cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE LOCATION
    SET PLOCJ = DECODE(LIBELLE, 'JARDINAGE', PLOCJ * 105/100, 'MENUISERIE', PLOCJ * 110/100)
    A tester !

  7. #7
    Membre chevronné Avatar de chrifo
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    444
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 444
    Par défaut
    Bonjour,

    Ca donnerait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    UPDATE LOCATION
        SET PLOCJ = decode(LIBELLE, 'JARDINAGE', PLOCJ * 105/100, 'MENUISERIE', PLOCJ * 110/100);
    Attention cet update passera à null tous les PLOCJ des LIBELLE autres que 'JARDINAGE' ou 'MENUISERIE'.
    A mon avis il vaut mieux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    UPDATE LOCATION
        SET PLOCJ = CASE WHEN LIBELLE = 'JARDINAGE' THEN PLOCJ * 105/100 ELSE PLOCJ * 110/100 END
        WHERE LIBELLE IN ('JARDINAGE','MENUISERIE');
    Soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    UPDATE LOCATION
        SET PLOCJ = decode(LIBELLE, 'JARDINAGE', PLOCJ * 105/100, PLOCJ * 110/100)
        WHERE LIBELLE IN ('JARDINAGE','MENUISERIE');

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

Discussions similaires

  1. Decrémenter un champ dans requete mise a jour
    Par scrat57000 dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 20/07/2007, 13h31
  2. pb requete mise a jour entre 2 tables
    Par lolothom dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 08/07/2007, 17h29
  3. [Requete]Mise a jour d'un champ
    Par le_gueux90 dans le forum Requêtes et SQL.
    Réponses: 13
    Dernier message: 11/05/2007, 11h52
  4. Est-ce Cela Peut Fonctionner Requetes Mise A Jour
    Par dauphin34000 dans le forum Oracle
    Réponses: 22
    Dernier message: 28/04/2006, 13h08
  5. Probleme avec une requete mise a jour
    Par mael94420 dans le forum ASP
    Réponses: 2
    Dernier message: 08/03/2006, 20h56

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