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 :

champ vide dans BD


Sujet :

Bases de données Delphi

  1. #1
    Membre actif Avatar de MANU_2
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    417
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 417
    Points : 275
    Points
    275
    Par défaut champ vide dans BD
    Dans une table paradox, j'ai des champs de type alphanumérique qui peuvent être vide.
    Lors de l'affichage de ces champs, ceux qui sont me génère une erreur : "Conversion de type variant incorrect".

    Comment faire pour ne pas avoir cette erreur ?

    Merci

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    Par défaut
    poster dans le forum Delphi et bases de données
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  3. #3
    Membre confirmé
    Avatar de Manopower
    Inscrit en
    Décembre 2003
    Messages
    516
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 516
    Points : 453
    Points
    453
    Par défaut
    quelle procédure utilises-tu pour lire ces champs ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dataset.fieldbyname('num').asvariant ?
    Dataset.fieldbyname('num').asvalue ?
    le plus propre (à mon goût) est d'adapter

    si ton champ est une chaine :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dataset.fieldbyname('num').asString; //Renvoie '' si le champ est null
    si c'est un entier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dataset.fieldbyname('num').asInteger; //Plante si le champ est null
    tu peux aussi vérifier si ton champ est null

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    If not Dataset.fieldbyname('num').isnull then
      //reste du code

  4. #4
    Membre actif Avatar de MANU_2
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    417
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 417
    Points : 275
    Points
    275
    Par défaut
    Citation Envoyé par -Sylvain Leray-
    quelle procédure utilises-tu pour lire ces champs ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dataset.fieldbyname('num').asvariant ?
    Dataset.fieldbyname('num').asvalue ?
    le plus propre (à mon goût) est d'adapter

    si ton champ est une chaine :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dataset.fieldbyname('num').asString; //Renvoie '' si le champ est null
    si c'est un entier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dataset.fieldbyname('num').asInteger; //Plante si le champ est null
    tu peux aussi vérifier si ton champ est null

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    If not Dataset.fieldbyname('num').isnull then
      //reste du code
    J'utilise ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
         BD.SQL.Add (tmp);
         BD.Open;
     
        if BD.RecordCount > 0
        then
        begin
             BD.First;
             nom_pers.Text       := BD['nom'];          // marche
             prenom_pers.Text    := BD['prenom'];   // marche
             tel_pers.Text       := BD['telephone'];    // ne marche pas car vide
    ...

  5. #5
    Membre confirmé
    Avatar de Manopower
    Inscrit en
    Décembre 2003
    Messages
    516
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 516
    Points : 453
    Points
    453
    Par défaut
    un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    telpere.text := BD.fieldbyname('telephone').asstring;
    devrait résoudre ton problème.

    car en effet le code que tu utilises pour remplir tes champs convertit tout en variant. Comme tu sais quels champs tu appelles, autant utiliser un asString, en plus ça se trouve ça doit être mieux au niveau des performances.

    Tiens nous au courant !

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

Discussions similaires

  1. Masquer un champ vide dans un formulaire access
    Par anassyto dans le forum IHM
    Réponses: 2
    Dernier message: 25/06/2013, 16h24
  2. Réponses: 6
    Dernier message: 23/01/2007, 10h17
  3. champ vide dans un DBDateTimePicker
    Par gregcat dans le forum Bases de données
    Réponses: 2
    Dernier message: 16/10/2006, 14h27
  4. Test evenement sur champ vide dans une table
    Par eddyG dans le forum Access
    Réponses: 3
    Dernier message: 30/05/2006, 17h02
  5. Total de champs vide dans un formulaire
    Par gretch dans le forum Langage
    Réponses: 2
    Dernier message: 09/05/2006, 11h53

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