Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 15/06/2007, 12h26   #1
Membre habitué
 
Avatar de tintin72
 
Inscription : septembre 2003
Messages : 595
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 595
Points : 123
Points : 123
Par défaut Arguments des types float, int ?

Bonjour,

Je ne comprends pas bien les arguments des types float, int etc dans mysql.
Lors de la création d'une table j'ai mis:
Code :
1
2
3
4
 
...
price FLOAT(5,2) NOT NULL, reference INT(10) NOT NULL, 
...
mais lorsque j'essais d'insérer les nombres:

12.48 (note: apparement mysql n'accepte pas de virgule)
et
1234567899

mysql m'affiche une erreur disant qu'il doit tronquer je sais pas quoi...bref

dans mon idée FLOAT(5,2) devrait pouvoir afficher
5 chiffres avant la virgule et 2 aprés: 55555,22
et INT(10) devrait pouvoir afficher
un nombre à 10 chiffres: 1234567899

Est ce que quelqu'un pourrait m'éclairer sur ces arguments et
sur la façon de s'en servir ?

Merci d'avance
tintin72 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2007, 16h05   #2
Modérateur
 
Avatar de Cybher
 
Homme Michel
Consultant informatique
Inscription : mai 2005
Messages : 3 006
Détails du profil
Informations personnelles :
Nom : Homme Michel
Âge : 29
Localisation : France

Informations professionnelles :
Activité : Consultant informatique
Secteur : Conseil

Informations forums :
Inscription : mai 2005
Messages : 3 006
Points : 4 039
Points : 4 039
salut,

un petit peu de lecture qui devrait t'éclairer :
http://dev.mysql.com/doc/refman/5.0/...ric-types.html
Cybher est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2007, 16h06   #3
Expert Confirmé
 
Avatar de berceker united
 
Développeur informatique
Inscription : février 2005
Messages : 2 982
Détails du profil
Informations personnelles :
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Développeur informatique

Informations forums :
Inscription : février 2005
Messages : 2 982
Points : 3 567
Points : 3 567
Citation:
Envoyé par tintin72
Bonjour,

Je ne comprends pas bien les arguments des types float, int etc dans mysql.
Lors de la création d'une table j'ai mis:
Code :
1
2
3
4
 
...
price FLOAT(5,2) NOT NULL, reference INT(10) NOT NULL, 
...
mais lorsque j'essais d'insérer les nombres:

12.48 (note: apparement mysql n'accepte pas de virgule)
et
1234567899

mysql m'affiche une erreur disant qu'il doit tronquer je sais pas quoi...bref

dans mon idée FLOAT(5,2) devrait pouvoir afficher
5 chiffres avant la virgule et 2 aprés: 55555,22
et INT(10) devrait pouvoir afficher
un nombre à 10 chiffres: 1234567899

Est ce que quelqu'un pourrait m'éclairer sur ces arguments et
sur la façon de s'en servir ?

Merci d'avance
Tu auras des explications ici. Il n'affiche pas spécialement x chiffre parce que tu as indiqué x. Il y a une intervalle de valeur acceptées.
__________________
Mon avatar ? Ce n'est rien, c'est juste la tête que je fais lorsque je vois un code complètement frappa dingue !...
berceker united est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/06/2007, 10h26   #4
Membre habitué
 
Avatar de tintin72
 
Inscription : septembre 2003
Messages : 595
Détails du profil
Informations forums :
Inscription : septembre 2003
Messages : 595
Points : 123
Points : 123
En fait c'est à cause de l'octet utilisé pour le signe.
Comme je n'ai pas indiqué UNSIGNED lors de la création de la table,
mysql a donc utilisé 1 octet pour "signer" la valeur.
ce qui fait que:
Code :
1
2
 
reference INT(10) NOT NULL,
affiche 9 chiffres et:
Code :
1
2
 
price FLOAT(5,2) NOT NULL,
affiche 1 chiffre aprés la virgule.

En indiquant UNSIGNED, l'affichage correspond bien à ce qui est attendu.

Voilà, je pense que c'est l'explication et c'est ce que j'ai cru comprendre
sur la page.
http://dev.mysql.com/doc/refman/5.0/...ric-types.html
Maintenant, si jamais je faisais fausse route n'hésitez pas à me le faire savoir .
tintin72 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 12h05.


 
 
 
 
Partenaires

Hébergement Web