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 MySQL Discussion :

Récupération dans une table d'un taux de change calculé à partir d'une autre table


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Femme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hauts de Seine (Île de France)

    Informations forums :
    Inscription : Janvier 2013
    Messages : 24
    Points : 24
    Points
    24
    Par défaut Récupération dans une table d'un taux de change calculé à partir d'une autre table
    Bonjour,

    Je suis débutant en SQL, j'ai regardé sur le forum mais je n'ai pas trouvé de solutions qui pourrait convenir.

    J'ai deux tables :

    Table1 : Table avec les taux de change - dont la base currency est toujours "EUR"

    Currency_fx Currency_base fx
    AUD EUR 1,6164
    CAD EUR 1,4706
    CHF EUR 1,1137
    DKK EUR 7,4634
    EUR EUR 1
    GBP EUR 0,89975
    HKD EUR 8,7508
    HUF EUR 325,46
    JPY EUR 121,93
    NOK EUR 9,6983
    PLN EUR 4,263
    USD EUR 1,1205

    Table 2 : Base client avec deux devises

    client currency1 currency2
    A USD USD
    B EUR EUR
    C EUR EUR
    D GBP GBP
    A EUR EUR

    je souhaiterai avoir le taux de change associé pour chaque client - Sachant que nous n'avons pas dans cette table tout le temps la paire "Devise / EUR"
    Le résultat attendu est le suivant :

    client currency1 currency2 Fx
    A USD USD 1 (1.105/1.1205)
    B GBP HUF 0,002764549 (0.89975/325.46)
    C EUR HKD 0,114275266 (1/8.7508)
    D GBP JPY 0,007379234 (0.89975/121.93)
    A CHF CAD 0,757309942 (1.1137/1.4706)

    Merci d'avance,

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Pour moi il faut faire une double conversion: une première de la devise du client vers EUR, et une deuxième vers la devise cible.
    Un truc du genre:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select d1.fx / d2.fx
    from client as c
    inner join devise as d1 on d1.CurrencyFx = c.CodeDevise
    inner join devise as d2 on d2.CurrencyFX = 'Le code devise à chercher'

    Tatayo.

  3. #3
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 909
    Points
    38 909
    Billets dans le blog
    9
    Par défaut
    Bonsoir

    Dans votre exemple, la table 2 contient systématiquement deux fois la même devise pour chaque client, du coup on peut s’interroger sur l'intérêt d'une telle table et surtout sur le résultat attendu...
    Par exemple : selon quel critère devrait on obtenir la ligne "B GBP HUF 0,002764549 (0.89975/325.46)" puisque le client "B" ne connait que la devise "EUR" d'après la table 2.
    Pourquoi GBP pour ce client, pourquoi HUF, pourquoi pas NOK ou USD pour ce même client ...?

    De plus, un taux de change n'a de sens habituellement qu'à date, or, votre table des taux n'est pas datée, surprenant également

Discussions similaires

  1. [ODBC] Récupération d'une donnée pour insertion dans une autre table
    Par rom950 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 10/03/2006, 17h13
  2. Numero non present dans une autre table
    Par AlphonseBrown dans le forum Langage SQL
    Réponses: 7
    Dernier message: 22/02/2005, 12h37
  3. concatenation des données d'une table dans une autre
    Par Fabby69 dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 04/10/2004, 11h38
  4. Réponses: 15
    Dernier message: 26/03/2004, 17h53
  5. copier une ligne dans une autre table
    Par BoeufBrocoli dans le forum SQL
    Réponses: 5
    Dernier message: 24/10/2003, 22h59

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