Update sql access

choupinette -  
 theoprof -
Bonjour,

j'ai une table compteur que je dois mettre a jour, pour cela j'ai écrit l'instruction suivante :

update compteur, tablebis set compteur.marge = compteur.marge + sum (tablebis.marge) ;
Mais il m'affcihe un message d'erreur : disant que j'essaye d'executer une requete ne comprenant pas l'experssion spécifiée "compteur.marge + sum (tablebis.marge)" comme une partie de la fonction d'agregat.

Je ne comprend pas pourquoi il m'affiche cela.

Voici le contenu de ma table compteur : marge
tablebis : agence, marge, quantité etc ....

Merci d'avance
A voir également:

7 réponses

Christounet Messages postés 1266 Statut Membre 1 393
 
Bonjour,

Tu ne peux pas utiliser deux noms de table dans un ordre update, un code correct serait
update compteur
set marge = marge + (select sum(marge) from tablebis)

A chaque requête, la colonne marge sera augmentée par la somme de la colonne marge de ta table tablebis, est-ce bien cela que tu veux ou bien veux-tu simplement avoir la somme de la colonne marge de ta table tablebis dans la colonne marge de ta table compteur, si c'est le cas alors le code serait
update compteur
set marge = (select sum(marge) from tablebis)

A plus
0
choupinette
 
et bien je veux que la somme de la marge de la tablebis vient s'ajouter à celle de la table compteur mais j'ai écrit ce que tu m'a dit et il affiche maintenant : l'opération doit utiliser une rêquete qui peut être mise à jour

c'est normal?
0
Christounet Messages postés 1266 Statut Membre 1 393
 
Bonjour,

Oups, j'ai lu trop vite, j'avais pas vu que tu utilisais access, l'ordre que je t'ai donné ne fonctionne pas.
Tu peux éventuellement obtenir ce que tu veux avec deux requêtes:
select sum(marge) from tablebis as TotalMarge into NouvelleTable
et après
update compteur set marge = marge . NouvelleTable.TotalMarge

La première requête fait la somme de la colonne marge et crée une nouvelle table, et ensuite tu utilises cette nouvelle table dans ta deuxième requête. Je ne suis pas un grand spécialiste d'Access.
Si cela peux t'aider.
A plus
0
choupinette
 
en fait le into ne fonctionne pas, mais g déjà récuperer la sum de la marge avec un requete donc si je la met dans une table avec un insert into après je peut faire un update à partie de la donnée que j'ai mise dans la table à partir du insert into?
0
Christounet Messages postés 1266 Statut Membre 1 393
 
Bonjour,

En fait, si tu as déjà la somme de la marge de la tablebis dans une variable (disons MonTotal), tu peux utiliser le code suivant
update compteur set marge = marge + MonTotal

A plus
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
choupinette
 
et bien quand j'écris l'instruction que tu me dis access m'ouvre une boite de dialogue ou je dois lui ecrire le montant de MonTotal.

En fait MonTotal resulte d'une requete je l'ai pas encore mis dans une table, sa fonctionnne quand même si c pas dans une table?
0
Christounet Messages postés 1266 Statut Membre 1 393
 
Bonjour,

Décidément, c'est pas mon jour, alors voici le code correct pour insérer la somme dans une nouvelle table et ensuite récupérer cette somme pour mettre à jour l'autre table:
SELECT sum(montant) as TotalMarge into NouvelleTable from tablebis
et
update compteur , NouvelleTable set marge = marge + NouvelleTable.TotalMarge

J'ai essayé les deux requêtes séparément et cela fonctionne.
A toi de voir
0
choupinette
 
c bon sa fonctionne merci beaucoup beaucoup beaucoup
0
Christounet Messages postés 1266 Statut Membre 1 393
 
De rien choupinette, CCM est là pour s'entraider.
A plus
0
theoprof > Christounet Messages postés 1266 Statut Membre
 
Salut,

je vous savoir comment transmettre un paramètre à une requête update pour mettre à jour le stock d'un produit.

merci
0