Additionner 2 champs de 2 tables [Résolu/Fermé]

Signaler
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020
-
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020
-
Bonjour, j'ai un problème, j'ai 2 tables différentes, l'une avec une colonne contenant des points de fidélité et l'autre avec une colonne contenant d'autres points et je voudrais le additionner et les stocker dans la première table à la place des premiers. Et je ne peux pas modifier la structure des tables. Bien évidemment, je veux faire ça dans tous les tuples et les 2 tables se relié par une key.

Pouvez-vous m'aider ?


Configuration: Windows / Chrome 73.0.3683.103

2 réponses

Messages postés
29138
Date d'inscription
mercredi 2 mai 2007
Statut
Modérateur
Dernière intervention
13 juillet 2020
6 504
Bonjour,

Avec Oracle je ferais :

update tabl1 set cpt1 = cpt1 + (select cpt2 from tabl2 where id1=id2);

Ce devrait être voisin avec sqlserver

Cdlt
Messages postés
29138
Date d'inscription
mercredi 2 mai 2007
Statut
Modérateur
Dernière intervention
13 juillet 2020
6 504 >
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020

tu as bien sur remplacé les noms de ma requete qui étaient tous des exemples ?

affiche ici ta requete et le message d'erreur exact
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020
2
update client
set client.fidelite = Client.fidelite + (select fidelite_acquise from calcul_client
                                                        where client.code = calcul_client.code_client)
where client.code in (select code_client from calcul_client where nb_passage >=3)

Messages postés
29138
Date d'inscription
mercredi 2 mai 2007
Statut
Modérateur
Dernière intervention
13 juillet 2020
6 504 >
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020

J'aurais un doute sur 2 sous select sur la même table dans une commande, après je n'ai jamais fait de sql avec SqlServer

et ?

update client
set client.fidelite = Client.fidelite + (select fidelite_acquise from calcul_client
   where client.code = calcul_client.code_client 
   and nb_passage >=3) 
Messages postés
3604
Date d'inscription
jeudi 16 juin 2005
Statut
Membre
Dernière intervention
3 juillet 2020
959
Bonjour,

Sous SQL Server ce serait plutôt quelque chose comme ceci :
UPDATE c
SET fidelite = c.fidelite + cc.fidelite_acquise
FROM client c
INNER JOIN calcul_client cc ON cc.code_client = c.code
WHERE cc.nb_passage >= 3


Xavier
Messages postés
29138
Date d'inscription
mercredi 2 mai 2007
Statut
Modérateur
Dernière intervention
13 juillet 2020
6 504 >
Messages postés
3604
Date d'inscription
jeudi 16 juin 2005
Statut
Membre
Dernière intervention
3 juillet 2020

merci, je suis de l'ancienne école et au départ sur oracle le JOIN n'existait pas ;-)
Messages postés
30
Date d'inscription
samedi 3 septembre 2016
Statut
Membre
Dernière intervention
27 mai 2020
2
Merci les gars, ma requête fonctionne !!