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

MS SQL Server Discussion :

update avec sum


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2004
    Messages
    127
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 127
    Points : 84
    Points
    84
    Par défaut update avec sum
    Bonjour

    Comment mettre à jour une valeur avec une valeur calculée dans une de mes tables ?

    Typiquement

    UPDATE MaTable
    SET LeChamp = SELECT SUM(convert(numeric,MONTANT))
    FROM x
    WHERE [...]

    (qui ne ne fonctionne pas)
    Erreur :

    Msg 156, Niveau 15, État 1, Ligne 21
    Syntaxe incorrecte vers le mot clé 'SELECT'.


    Alors qu'en rajoutant des parenthèses devant le select ça passe (pas d'erreur) mais ça ne fait pas l'update !!
    :S

    Quelqu'un a-t-il une solution ??

  2. #2
    Membre actif
    Inscrit en
    Février 2006
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 185
    Points : 224
    Points
    224
    Par défaut
    Salut,

    Si je comprends bien, tu as 2 tables (matable et x) et tu veux faire un update en prenant comme nouvelle donnée une valeur calculée provenant d'une autre table.

    Si c'est le cas , tu devrais avoir:

    1- si ta condition est appliquée sur la table à modifier
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    UPDATE MATABLE
    SET    LECHAMP = (SELECT SUM(CONVERT(NUMERIC,MONTANT))
                      FROM   X)
    WHERE  [...]
    2- si ta condition est appliquée sur la table x
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    UPDATE MATABLE
    SET    LECHAMP = (SELECT SUM(CONVERT(NUMERIC,MONTANT))
                      FROM   X
                      WHERE  [...])

  3. #3
    Membre régulier
    Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2004
    Messages
    127
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 127
    Points : 84
    Points
    84
    Par défaut
    C'est typiquement le cas 2.

    Le seul problème par rapport à ça, c'est qu'il ne m'update aucun champ dans la base

    Même si la requête arrive 'sans erreur' à son terme.

  4. #4
    Membre actif
    Inscrit en
    Février 2006
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 185
    Points : 224
    Points
    224
    Par défaut
    es-tu sur qu'il n'y a pas une autre condition à ton update?
    car si tu as des données dans ta table "matable", cette requete devrait modifier la colonne "lechamp" de tous les enregistrements.

    Postes l'ensemble de ta requete on verra

Discussions similaires

  1. Pb update avec jointure et sum et decode
    Par lepetitjo dans le forum Langage SQL
    Réponses: 3
    Dernier message: 11/07/2013, 17h55
  2. PB Requete UPDATE avec CASE et SUM
    Par Avatar69 dans le forum Requêtes
    Réponses: 0
    Dernier message: 03/07/2013, 15h51
  3. Requête update avec SUM
    Par stos dans le forum Requêtes
    Réponses: 4
    Dernier message: 06/06/2011, 15h50
  4. UPDATE avec sum
    Par lazag dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/02/2010, 12h22
  5. Réponses: 3
    Dernier message: 22/12/2005, 17h47

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