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

Bases de données Delphi Discussion :

erreur de conversion d'un champ numerique


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut erreur de conversion d'un champ numerique
    salut tt le monde
    j'ai un champ vte_n de type numeric que je veux utiliser comme condition ds ma requette mais ça me déclenche une erreur de conversion de variant de type srting en type currency, sachant que reg_n d'une autre requette est de type numeric aussi
    j'ai essayé plusieurs solutions mais en vain

    voici ma requette
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    with QRec do begin
           with sql do begin
                 clear;
                 add('select * from vte_reg where ');           
                 add('vte_n =cast('''+DM.QRegClt.FieldValues['reg_n']+''' as ');
                 add(' numeric) ');
           end;
           open;
    end;
    Merci à tout le monde

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 98
    Points : 72
    Points
    72
    Par défaut
    je comprends pas si vte_n et reg_n sont tout les deux numeric pourquoi tu fait un cast ?

    ton erreur est elle bien une erreur sql ?
    ( je convertis jamais dans mes requetes, je le fait tjrs avant )

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut meme sujet
    la variable DM.QRegClt.FieldValues['reg_n'] la considère comme une chaine string , alors meme si je fais pas de cast il me genère le meme msg d'erreur

    j'ai essayé d'affacter DM.QRegClt.FieldValues['reg_n'] à une variable de type numeric mais quand j'utilise cette variable ds la requette il me dit que c'est un type incompatible
    je travaille avec sql server, si vous avez déjà fais une requette avec un champ numeric comme mon cas veuillez me donner cet exemple, peut etre que ça m'aidera.
    thanks

  4. #4
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Salut

    Essaye comme ceci sans utiliser de cast:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    with QRec do begin
           with sql do begin
                 clear;
                 add('select * from vte_reg where ');           
                 add('vte_n = ' + DM.QRegClt.FieldByName('reg_n').AsCurrency);
           end;
           open;
    end;
    @+ Claudius

  5. #5
    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
    Citation Envoyé par Cl@udius
    Salut

    Essaye comme ceci sans utiliser de cast:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    with QRec do begin
           with sql do begin
                 clear;
                 add('select * from vte_reg where ');           
                 add('vte_n = ' + DM.QRegClt.FieldByName('reg_n').AsCurrency);
           end;
           open;
    end;
    @+ Claudius

    Pas sur que cela fonctionne avec un currency

    avec AsString je pense que cela fonctionnera beaucoup mieux

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    add('vte_n = ' + DM.QRegClt.FieldByName('reg_n').AsString);
    Modérateur Delphi

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

  6. #6
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Citation Envoyé par Malatar
    Pas sur que cela fonctionne avec un currency
    J'ai choisi AsCurrency au regard de son message d'erreur:
    Citation Envoyé par da_latifa
    mais ça me déclenche une erreur de conversion de variant de type srting en type currency
    Mais tu as n'a pas tort, si n'a ne passe pas, ça doit pouvoir passer avec AsString. Quoique suivant la valeur de DecimalSeparator !!


    @+

  7. #7
    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
    Citation Envoyé par Cl@udius
    J'ai choisi AsCurrency au regard de son message d'erreur:


    Mais tu as n'a pas tort, si n'a ne passe pas, ça doit pouvoir passer avec AsString. Quoique suivant la valeur de DecimalSeparator !!


    @+
    Le problème c'est que AsCurrency retourne un Currency, donc c'est sûr que ca va retourner une erreur surtout dans le Add d'un .SQL ^^
    Modérateur Delphi

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

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 98
    Points : 72
    Points
    72
    Par défaut
    >< j'crois que claudius a du mettre le doigt sur le souci ^^ ca serais pas le decimal separator qui causerais l'erreur ?
    car la de tt facon vu que c un variant il doit fait un transtypage en string ... malheureusement si le decimalseparator est mauvais ^^ la requete sql plantera lamentablement avec une erreur du type "erreur de conversion de variant de type string en type currency".
    enfin moi ca m'ai deja arrivé.

    essaye

    Mem := decimalseparator;
    decimalseparator := '.' ou ',' // je ne sais plus lequel c'est ><

    ->requete

    decimalseparator := Mem;

  9. #9
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Citation Envoyé par Malatar
    Le problème c'est que AsCurrency retourne un Currency,
    Oulalala !! Je suis complètement à côté de la plaque. J'ai pourtant bien dormi cette nuit.

    Je n'ai rien dit, sinon of course AsString.

    @+

  10. #10
    Expert éminent sénior
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Points : 10 008
    Points
    10 008
    Par défaut
    Citation Envoyé par Caesarus
    decimalseparator := '.' ou ',' // je ne sais plus lequel c'est
    le point ( . ) dans 99,9% des cas. Sans connaitre le 0,1%

    @+

  11. #11
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    98
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 98
    Points : 72
    Points
    72
    Par défaut
    j'avoue que je me suis demander si tu avais pas fumer ton clavier ^^
    t'as quand meme pensé au decimalseparator ^^

  12. #12
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut meme sujet
    merci bq bq les gars , ça a marché avec AsString
    vous etes vraiement super

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 18/09/2014, 13h43
  2. Réponses: 7
    Dernier message: 25/09/2009, 10h02
  3. Erreur de conversion de type Null en String
    Par navis84 dans le forum Bases de données
    Réponses: 3
    Dernier message: 26/07/2005, 15h25
  4. Erreur de conversion int to socklen_t
    Par def_jam_vendetta dans le forum C++
    Réponses: 6
    Dernier message: 04/03/2005, 10h53
  5. Increment d'un champ numerique
    Par oazar dans le forum Langage SQL
    Réponses: 2
    Dernier message: 17/04/2004, 23h28

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