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 Procédural MySQL Discussion :

Troncation de valeurs doubles ?


Sujet :

SQL Procédural MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Par défaut Troncation de valeurs doubles ?
    Bonjour,

    Savez vous pourquoi les données doubles dans l'exemple suivant sont tronquées ? Et comment y remédier ?

    Merci d'avance.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    mysql> create table double_test (d double);
     
    Query OK, 0 rows affected (0.00 sec)
     
     
    mysql> insert into double_test values(1.7976931348623157E308);
     
    Query OK, 1 row affected (0.00 sec)
     
     
     
    mysql> insert into double_test values(0.10012210012209899);
     
    Query OK, 1 row affected (0.00 sec)
     
     
     
    mysql> select * from double_test;
     
    +-----------------------+
     
    | d                     |
     
    +-----------------------+
     
    | 1.79769313486232e+308 | -> truncation !!
     
    |     0.100122100122099 | -> truncation !!
     
    +-----------------------+
     
    2 rows in set (0.00 sec)

  2. #2
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 672
    Par défaut
    apparement tu as atteints la limite de precision du type "double"
    le type de champ qui permet de stocker une plus grand precision est "varchar"

  3. #3
    Membre Expert
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Par défaut
    J'ai testé avec MySQL 4 et 5 et le résultat est le même.

    Existe t'il des solutions ?

  4. #4
    Expert confirmé
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 672
    Par défaut
    Citation Envoyé par elitost
    J'ai testé avec MySQL 4 et 5 et le résultat est le même.
    avec un champ "varchar" ? tu as rajouté des guillemets simples autour de tes valeurs ?

  5. #5
    Membre Expert
    Avatar de elitost
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2003
    Messages
    1 985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 985
    Par défaut
    Non, seulement avec le type double.

    Pour le moment je me vois mal modifier toute l application pour utiliser des varchar.

    Existe t il un moyen de paramètrer le type double pour éviter cette troncation ?

Discussions similaires

  1. [CR XI] Paramètres dynamiques en cascade - valeurs à double
    Par Asyndra dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 20/08/2009, 09h01
  2. Réponses: 0
    Dernier message: 24/11/2008, 13h02
  3. Une valeur Double dans JSF
    Par jeedev dans le forum JSF
    Réponses: 1
    Dernier message: 10/10/2008, 18h56
  4. Verifier le type d'une string contient une valeur double
    Par tangueros dans le forum VBA Access
    Réponses: 2
    Dernier message: 19/06/2007, 12h56
  5. [Tableaux] Foreach renvoie des valeurs double en php4
    Par Dantahoua dans le forum Langage
    Réponses: 5
    Dernier message: 10/04/2007, 17h49

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