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 :

Pb de type de champs dans une requête


Sujet :

Bases de données Delphi

  1. #1
    Nouveau membre du Club
    Inscrit en
    Octobre 2004
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 61
    Points : 28
    Points
    28
    Par défaut Pb de type de champs dans une requête
    Bonjour TLM

    j'ai un champs de type alphanumerique (EXRET) et je vais faire un condition dans une requête où ce champs et superieur a une valeur (retd et retf entier)

    je sais que ce ne vas pas marché car le champs contient des caractère d'où l'erreur d'incompatibilité de type entre entier et String.

    y'a t'il une solution ???

    CODE

    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
     
    [size=9]retd := strtoint(Edit15.Text);
    retf := strtoint(Edit16.Text);
     
    query1.Close  ;
    query1.sql.clear;
    query1.Sql.text :=  'Select * from Expl  Where EXDAT>=(:date_d) and EXDAT<=(:date_f) '  ;
     
    If (retd >0  ) Then  Begin
                          query1.sql.add('and EXRET>=(:rd) ');
                          query1.ParamByName('rd').AsInteger := retd;
                          End;
    If (retf >0  ) Then  Begin
                          query1.sql.add('and EXRET<=(:rf) ');
                          query1.ParamByName('rf').AsInteger := retf;
                          End;
     
    query1.ParamByName('date_d').AsDateTime := strtodate(datd);
    query1.ParamByName('date_f').AsDateTime := strtodate(datf);
    query1.Open;[/size]

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 56
    Points : 45
    Points
    45
    Par défaut
    Pourquoi tu ferais pas ???

    C'est peut-etre pas ce que tu veux

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    retd := strtointDef(Edit15.Text,0); 
    retf := strtointDef(Edit16.Text,0);

  3. #3
    Nouveau membre du Club
    Inscrit en
    Octobre 2004
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 61
    Points : 28
    Points
    28
    Par défaut
    le problème est que EXRET et de type Alphanumerique, et moi je veux faire une comparaison avec des chiffres ce qui génére l'erreur, "type incompatible entre String et Integer pendant l'exécution de la requête SQL

  4. #4
    Nouveau membre du Club
    Inscrit en
    Juillet 2002
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 40
    Points : 32
    Points
    32
    Par défaut
    c'est normal cette erreur.

    il suffit donc de changer EXRET en numérique est le problème est résolu.
    A mon avis, c'est la seule solution pour faire comparaison à ce champ.
    bonjour tous le monde,

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 265
    Points : 290
    Points
    290
    Par défaut
    Salut

    Tu transtypes ton champ EXRET en entier.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ...
                   query1.sql.add('and CAST(EXRET AS INTEGER)>=(:rd) ');
    ...
    @+

  6. #6
    Nouveau membre du Club
    Inscrit en
    Octobre 2004
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 61
    Points : 28
    Points
    28
    Par défaut
    ca marche a merveille avec ta solution zatoubux, merci infiniment

    PS : j'ai du travaillé en gardant que le type String (pour EXRET et les variables retd et retf) et ca marché aussi, mais la solution de zatoubux et plus pratique et merci aussi pour les autres.

    bonne astuces

    retd := strtointDef(Edit15.Text,0);
    retf := strtointDef(Edit16.Text,0);

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

Discussions similaires

  1. Définir le futur type de champ dans une requête création de table
    Par Fredo67 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 16/02/2007, 18h19
  2. Tester l'existence d'un champ dans une requête
    Par Reidid dans le forum Access
    Réponses: 3
    Dernier message: 23/01/2006, 22h02
  3. Réponses: 9
    Dernier message: 17/10/2005, 17h13
  4. Changement valeur d'un champ dans une requête
    Par Mimile28 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 07/04/2005, 14h28
  5. [SQL] Renommer un champ dans une requête
    Par martonpylon12 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 15/11/2003, 01h59

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