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

 Delphi Discussion :

Affecter une valeur NULL à un paramètre d'un Query ?


Sujet :

Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 165
    Par défaut Affecter une valeur NULL à un paramètre d'un Query ?
    Bonsoir,

    je fais une requete par Query et je voudrais passer mes valeurs par Parametre.

    Or je voudrais affecter NULL a certaines valeurs de la base qui sont de type varchar, bigint, datetime etc mais pas moyen de pouvoir y arriver sous delphi.

    J'ai essaye un truc de ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
            SQLQuery.ParamByName('LOGIN').Value := NULL;
    mais au mieux je me retrouve avec un element "vide" ( => '') dans ma base, au lieu d avoir un blocage a la mise a jour (not null)


    Une idee ?

    Merci.

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 165
    Par défaut
    j ai essaye ca aussi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
            SQLQuery.ParamByName('LOGIN').Value := NULL;
            SQLQuery.ParamByName('LOGIN').Bound := True;
    sans resultat non plus, tjs insertion chaine vide

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    16
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 16
    Par défaut
    Salut,

    il y a une ou deux choses qui ne sont pas très claires pour moi :
    tu affectes null à ton parambyname... donc à un paramètre de ta requête j'imagine... ce qui sous entend que ta requête est une requête d'insertion ?

    - si oui, je pense que 1) tu ne fais pas la meilleure utilisation possible des Query, et 2) la vérification du null doit se faire au niveau de la base de données.

    - si non, je crains de ne pas bien avoir compris ta question...

    Dans les deux cas, un peu plus d'infos sur le contexte seraient les bienvenues...

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 165
    Par défaut
    Bonjour,

    j'ai une fonction generique d'insertion d'un tuple dans ma table.

    Un truc du style :

    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
     
    SQLDataBase.StartTransaction;
    try
        SQLQuery.SQL.Text := 'INSERT INTO `Users`('+
                                        ' `dbLOGIN`,'+
                                        ' `dbNAME`,'+
                                        ' `dbRIGHTS`,'+
                                        ' `dbACTIVATED`'+
                                        ' ) '+
                                        'VALUES(:LOGIN, :NAME, :RIGHTS, :ACTIVATED)';
        SetParams( aUser);
        SQLQuery.ExecSQL;
        SQLDataBase.Commit;
    except
        SQLDataBase.Rollback;
    end;
    Et donc je voudrais affecter mes parametres avec leurs valeurs.
    Or j'ai mis dans la db (mysql) que dbLogin etait NOT NULL, justement pour que la requete d insertion "plante" si ce n etait pas le cas.

    Il n'est pas possible d initialiser un string a NULL, donc j aurais aimé passer NULL a mon parametre si le login nest pas renseigné (si je mets login := '' je vais me retrouver avec un user sans login, ce n est pas mon souhait).

    Bien entendu, je pourrais faire des tests dans l appli pour verifier le renseignement de login ou non, mais je pensais qu'une contrainte d'integrite servait aussi à cela.


    Merci

    nb: que cela soit d insertion, ou d update peu importe cela ne change rien.... il doit bien etre possible de passer NULL à la requete pour certaines valeurs ?

    Autre exemple plus simple :

    j ai une autre table avec une cle etrangere sur la table des users, or je ne veux pas forcement renseigne cette valeur (donc null par defaut, la db ne verifie pas la contrainte d integrite de la cle etrangere si la valeur est null).
    Mais dans mon appli, pas moyen de savoir si ce user va etre renseigne ou non, donc au depart j ai une initialisation à -1 de l index, or je ne peux pas inserer -1, mais par contre la ca serait super utile d affecter NULL au parametre.


    Une idée ?

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 60
    Par défaut
    Que ce passe t il si tu ne renseigne pas le parametre ?
    Du genre :

    If valeur <> nil then query.parambyname(xxxx).value := valeur

  6. #6
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 489
    Par défaut
    salut,

    il ne faut pas indiquer de valeur mais à l'inverse il faut "nettoyer" le champs


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
       SQLQuery.ParamByName('LOGIN').Clear;
       SQLQuery.ParamByName('LOGIN').Bound := True;

    @+ Phil

Discussions similaires

  1. [AC-2000] Affecter une valeur nulle à un champs
    Par forges dans le forum VBA Access
    Réponses: 2
    Dernier message: 11/04/2012, 07h57
  2. [AC-2003] Affecter une valeur nulle à un entier avant l'exécution de la requête
    Par flet le kid dans le forum VBA Access
    Réponses: 4
    Dernier message: 23/06/2009, 18h17
  3. Réponses: 3
    Dernier message: 10/06/2009, 22h03
  4. Réponses: 1
    Dernier message: 30/01/2008, 19h41
  5. CR XI : Traduire une valeur nulle et paramètre date
    Par dalhia101 dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 11/12/2007, 11h45

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