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

Requêtes et SQL. Discussion :

Calculs entre deux tables [AC-2007]


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut Calculs entre deux tables
    Bonjour,

    je voudrais faire une mise à jour dans une table via calcul qui prends en compte des données d'une autre table. Exemple :
    Table 1 :
    coefficient | X | Y
    fort | 6 | 5
    moyen | 4 | 3
    faible | 2 | 1


    Table 2 :
    legumes | type | NB | Prix
    carrote | X | 5 | NB * X;fort
    haricot | Y | 20 | NB * Y;fort
    patate | X | 50 | NB * X;fort


    Le prix étant ce que je dois calculer...
    Je pensais le faire via la fonciton VraiFaux : Si(type = "X";NB * X;fort;NB *Y;fort)

    Mais ce sont justement les champs vrai et faux que je n'arrive à remplir. Je ne sais pas comment lui dire d'aller chercher le "6" du X et pas le "5" du Y ...

    Je en sais pas si je suis vraiment claire...

    Le but étant que si une valeur change, tout se mette à jour automatiquement.

    Merci pour vos réponses,

    Pounette

  2. #2
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Salut,

    Quelque chose comme cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE T_TABLE2, T_TABLE1 SET T_TABLE2.PRIX = IIf(T_TABLE2.PRIX = "X", T_TABLE2.NB * T_TABLE1.X , T_TABLE2.NB * T_TABLE1.Y) 
    WHERE T_TABLE1.COEFFICIENT = "fort";
    @+.
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  3. #3
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    MERCI ! T'es un génie !!!

  4. #4
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    Juste pour complexifier la chose... Si par hasard je dois multiplier mon indicateur fort par l'indicateur moyen ...


    ça donenrai quoi, parce que si je rajoute dans la clause "where", il ne faut pas qu'il se mélange ...

  5. #5
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE T_TABLE2, T_TABLE1 SET T_TABLE2.PRIX = IIf(T_TABLE2.PRIX = "X", T_TABLE2.NB * T_TABLE1.X , T_TABLE2.NB * T_TABLE1.Y) 
    WHERE T_TABLE1.COEFFICIENT = "moyen";
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  6. #6
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    euh non je veux garder mon indicateur "fort", en gros :

    12 UPDATE T_TABLE2, T_TABLE1 SET T_TABLE2.PRIX = IIf(T_TABLE2.PRIX = "X", T_TABLE2.NB * T_TABLE1.X * T_TABLE1.X , T_TABLE2.NB * T_TABLE1.Y * T_TABLE1.Y)
    WHERE T_TABLE1.COEFFICIENT = "moyen" and T_TABLE1.COEFFICIENT = "fort";

    sauf que là y a confusion...

  7. #7
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Je ne comprends pas trop ce que tu veux faire !!!

    legumes | type | NB | Prix
    carrote | X | 5 | NB * X(fort) * X(moyen)
    haricot | Y | 20 | NB * X(fort) * X(moyen)
    patate | X | 50 | NB * X(fort) * X(moyen)

    C'est ça...
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  8. #8
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    bon alors on va dire :

    coefficient | X | Y
    fort | 6 | 5
    moyen | 4 | 3
    faible | 2 | 1
    poids | 0.5 | 0.7

    Table 2 :
    legumes | type | NB | Prix
    carrote | X | 5 | NB * X;fort *X;poids
    haricot | Y | 20 | NB * Y;fort*Y;poids
    patate | X | 50 | NB * X;fort*X;poids


    Si(type = "X";NB * X.fort * poids.X ;NB *Y.fort * poids.Y)

    En gros multiplier le nombre X le coefficient X le poids

    C'est mieux ?

    Sauf que du coup lorsque je veux définir le coefficient ce n'est plus très clair en sql ...

  9. #9
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Quelque chose comme cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE T_TABLE2, T_TABLE1 AS FORT, T_TABLE1 AS POIDS 
    SET T_TABLE2.PRIX = IIf(T_TABLE2.PRIX = "X", T_TABLE2.NB * FORT.X * POIDS.X , T_TABLE2.NB * FORT.Y * POIDS.Y) 
    WHERE FORT.COEFFICIENT = "moyen" AND POIDS.COEFFICIENT = "poids";
    @+.
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  10. #10
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    une boite de dialogue s'ouvre et me demande d'entrer une valeur de
    FORT.COEFFICIENT et POIDS.COEFFICIENT

    C'est normal ou c'est moi qui me suis trompée ?

  11. #11
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Cela ne te demande pas FORT.X, POIDS.X, FORT.Y et POIDS.Y ?
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  12. #12
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2012
    Messages : 119
    Points : 54
    Points
    54
    Par défaut
    ah non j'ai vu mon erreur

    En faite j'ai fais erreur, t'es pas un génie, t'es un dieu du sql ;-)

    Merci beaucoup pour ton aide ! Vraiment

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

Discussions similaires

  1. Calcul nombre d'enregistrements entre deux tables
    Par apprentis_sql dans le forum Langage SQL
    Réponses: 1
    Dernier message: 24/03/2014, 07h30
  2. [WD18] Calcul entre deux colonnes d'une table
    Par Alex1993 dans le forum WinDev
    Réponses: 4
    Dernier message: 19/09/2013, 08h20
  3. Calculer des champs entre deux tables
    Par bhami9 dans le forum Bases de données
    Réponses: 7
    Dernier message: 12/10/2010, 18h34
  4. [AC-2007] Calcul conditionnel entre deux tables
    Par Wanaka dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 27/04/2009, 10h51
  5. calcul entre deux champs dans une table
    Par pomar dans le forum Access
    Réponses: 7
    Dernier message: 29/11/2006, 18h27

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