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

Langage Delphi Discussion :

String et null pour updatesql


Sujet :

Langage Delphi

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut String et null pour updatesql
    Bonjour,

    j'ai un petit problème avec le driver ODBC de SQLbase.

    Après lecture d'un enregistrement, je fais saisir une valeur de type string dans un DbEdit. Si l'utilisateur saisi une valeur voire un espace c'est OK. Si l'utilisateur saisi une chaîne vide (donc = '') alors l'instruction ApplyUpdates me retour l'erreur
    [ODBC Driver]String data, right truncation
    La requête de mon objet UpdateSql est (MonsStr accepte null en base) :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    update MaTable set MonStr = :MonStr where  MaClef = :MaClef
    Si j'écris
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    update MaTable set MonStr = null where  MaClef = :MaClef
    , c'est OK.

    Deux solutions, soit j'écris mes requêtes de mise à jour et de création en dynamique en testant chaque champ pour savoir s'il faut mettre null ou pas (bonjour le boulot vu le nombre de tables et de champs !), soit je trouve une solution du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if QueryMonStr.AsString = '' then QyeryMonStr.AsString = null;
    (instruction qui génère actuellement une erreur à la compilation).

    D'où ma question, comment transposer mon string en null pour conserver l'automatisme de l'objet UpdateSql ?

    Merci.

  2. #2
    Membre confirmé Avatar de JustMe
    Inscrit en
    Juillet 2002
    Messages
    479
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 479
    Points : 593
    Points
    593
    Par défaut
    Peut être :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    QyeryMonStr.AsVariant := null;
    <On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**

  3. #3
    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
    ou bien, la méthode Clear de TField:
    @+

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    JustMe on n'a pas le droit d'utiliser cette formulation pour un string, cela génère une erreur d'application. Merci quand même.

    Cl@udius bonne idée (que n'y ais-je pensé ?). J'essaie. Ok c'est bon. Merci beaucoup.

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

Discussions similaires

  1. donner une valeur nulle pour une liste déroulante
    Par sam01 dans le forum Langage
    Réponses: 3
    Dernier message: 15/10/2006, 15h45
  2. [insertion]0 et non NULL pour un champ real
    Par Tchinkatchuk dans le forum PostgreSQL
    Réponses: 10
    Dernier message: 12/07/2005, 18h19
  3. Réponses: 2
    Dernier message: 15/03/2005, 09h13
  4. [VB.NET] Valur null pour une date.
    Par Lois dans le forum Windows Forms
    Réponses: 2
    Dernier message: 20/12/2004, 14h38
  5. Réponses: 9
    Dernier message: 10/08/2004, 17h13

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