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

SQL Firebird Discussion :

Conseil sur CAST


Sujet :

SQL Firebird

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    838
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 838
    Points : 262
    Points
    262
    Par défaut Conseil sur CAST
    bonjour,

    je voudrais savoir quelle est la meilleur manière pour faire un cast:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select sum((cast(ACHAT.ACCOEFDEV * L_ACHAT.LAPRIX * L_ACHAT.LAQTE as decimal(15,4)) * cast((1 - (L_ACHAT.LATAUXREM/100))  as decimal(15,4)))) as MHT from L_ACHAT
    join achat on achat.acidachat=l_achat.laidachat
    Au départ j'avais seulement le cast sur la deuxième partie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    cast((1 - (L_ACHAT.LATAUXREM/100))  as decimal(15,4))
    car cela me semble indisppensable à cause de la division.


    Mais avec la fonction SUM , cela ne passait plus, a cause d'une erreur d'overflow, ce qui est logique.

    J'ai donc rajouté un cast sur les 3 autres champs.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    cast(ACHAT.ACCOEFDEV * L_ACHAT.LAPRIX  * L_ACHAT.LAQTE as decimal(15,4))
    Et l'on retrouve le code écrit en haut de cette page. Il fonctionne bien, mais est ce que c'est bien correct ? et optimun ?
    Est ce qu'il ne faut pas remettre un cast globale qui encapsule les 2 cast de la requete ?

    Petite précision: tout les champs sont de types decimal(15,4).

    cordialement

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Quelle base de données ?
    (D’ailleurs quel rapport avec Delphi ?)
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 447
    Points : 24 849
    Points
    24 849
    Par défaut
    Tu as des forums plus spécialisés sur les SGBD, tu ne nous indique pas le moteur que tu utilises, je suis persuadé que pour ce genre de syntaxe, il est difficile de généraliser !

    Pour un logiciel en Apollo\Dbase migré en MyDAC\MySQL, je n'ai jamais eu besoin de faire des CAST pour effectuer des calculs de Compta pour un outil de Gestion Commercial (300 000 Clients d'un petit éditeur de presse), je n'avais pas d'erreur d'arrondi particulière
    Beaucoup de calcul étant fait en Delphi lié à la nature même du code existant en DBase migré vers MySQL, pas toujours évident de tout réécrire en SQL

    Pour un logiciel en BDE\Paradox migré en ADO\Oracle, le SQL (très bien écrit à l'origine avec TQuery et Paramètres) n'a quasiment pas été changé et pourtant c'est un outil de Gestion Financière avec beaucoup de calculs liés taux de change (6 digit après la virgule indispensable avec un compte d'arrondi pour les éventuels erreur)
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    838
    Détails du profil
    Informations personnelles :
    Âge : 58
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 838
    Points : 262
    Points
    262
    Par défaut précision
    bonjour,

    Effectivement j'ai oublié le moteur de DB: c'est firebird 2.1
    J'utilise Delphi 2007 avec les compo IBX (je sais c'est pas le top mais je passerais au Fibplus bientot)

    cordialement

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

Discussions similaires

  1. [JSP-Servlet] Conseils sur façon de coder
    Par gunnm dans le forum Servlets/JSP
    Réponses: 20
    Dernier message: 09/12/2004, 20h57
  2. Conseil sur modélisation
    Par Tankian dans le forum Schéma
    Réponses: 7
    Dernier message: 11/08/2004, 11h13
  3. cherche conseil sur livre pour jbuilder
    Par med1 dans le forum JBuilder
    Réponses: 3
    Dernier message: 09/06/2004, 13h33
  4. [débutant] conseils sur contraintes et alter table
    Par maysa dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 26/05/2004, 09h03
  5. Recherche Livre / Conseils sur la conception de Base
    Par Yeuma dans le forum Décisions SGBD
    Réponses: 7
    Dernier message: 02/01/2004, 14h25

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