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

Django Python Discussion :

Django : comment stocker string un champ vide avec Null dans ma base et non pas '' (empty)


Sujet :

Django Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2011
    Messages
    257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2011
    Messages : 257
    Par défaut Django : comment stocker string un champ vide avec Null dans ma base et non pas '' (empty)
    Bonjour,

    Je développe un nouveau projet Django

    J'ai un modèle Randomisation et un formulaire RandomizationEditForm.
    2 champs de ce formulaire (un CharField et un DateField) sont conditionnés à la valeur sélectionné dans le champ les précédent. J'utilise JS pour çà.

    Dans mon modèle, les 2 champs conditionnés sont null=True et blank=True. Ce qui, si j'ai bien compris l'intérêt des ces paramètres, permet de stocker une valeur nulle dans la base et de laisser vide à la validation du formulaire. C'est ce que je souhaite comme comportement.

    Et pourtant, je suis obligé d'ajouter required=False dans mon formulaire, sinon la validation ne passe pas. C'est le premier point que je ne comprends pas.

    Mais surtout, je ne sais pas pourquoi la valeur stockée lorsque je ne saisi rien dans le champ conditionné CharField est '' (empty) alors que je souhaite que ce soit NULL.
    Pour être honnête, je recylcle du code que j'ai utilisé sur un autre de mes projet et je n'ai jamais eu ce problème et je pensais avoir compris le fonctionnement...
    D'avance merci poru votre aie


    models.py
    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
    class Randomisation(models.Model):
     
        ran_ide = models.AutoField(primary_key=True)
        pay_ide = models.CharField("Patient's country code", max_length=2, null=True, blank=True)
        ran_str_num = models.CharField("Logical numerotation", max_length=2, null=True, blank=True)
        ran_bra = models.CharField("Arm", max_length=1, null=True, blank=True)
        bra_lib = models.CharField("Arm label", max_length=50, null=True, blank=True)
        ran_act = models.IntegerField("Activated line", null=True, blank=True)
        pat = models.CharField("Patient number", max_length=12, unique=True, null=True, blank=True)
        ran_nai = models.IntegerField("Patient birthdate (year)", blank=True)    
        ran_sex = models.IntegerField("Sex", null=True, blank=True)
        ran_st1 = models.IntegerField("Stratification variable 1", blank=True)
        ran_st2 = models.IntegerField("Stratification variable 2", blank=True)
        ran_bug = models.IntegerField("Use of alternative randomization procedure?", null=True, blank=True)
        ran_dem_nom = models.CharField("Name of the person asking for randomization", max_length=12, null=True, blank=True)
        ran_dem_dat = models.DateTimeField("Date of demand", null=True, blank=True)
        ran_log = models.DateTimeField("User", null=True, blank=True)
        ran_dat = models.DateTimeField("Date", null=True, auto_now_add=True, blank=True)
    form.py
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    class RandomizationEditForm(forms.ModelForm):
     
        def __init__(self, request, *args, **kwargs):
            super(RandomizationEditForm, self).__init__(*args, **kwargs)
            self.user_country = request.session.get('user_country')
            self.language = request.session.get('language')
            self.user_site_type = request.session.get('user_site_type')        
            PAYS = Pays.options_list(self.user_country,self.user_site_type,self.language)
            SEXE = [(None,''),(1,'Male'),(2,'Female')]
            STRATE_1 = [(None,''),(1,'strate 1 condition 1'),(2,'strate 1 condition 2')]
            STRATE_2 = [(None,''),(1,'strate 2 condition 1'),(2,'strate 2 condition 2')]
            YES = [(0,''),(1,'Yes'),]
     
            self.fields["pay_ide"] = forms.ChoiceField(label = "Patient's country code", widget=forms.Select, choices=PAYS, initial = self.user_country, disabled=True)
            self.fields["ran_str_num"] = forms.CharField(label = "Logical numerotation", initial = 1, widget=forms.HiddenInput())
            self.fields["ran_bra"] = forms.CharField(label = "Arm", initial = 1, widget=forms.HiddenInput())
            self.fields["bra_lib"] = forms.CharField(label = "Arm label", initial = 'Hydroxychloroquin', widget=forms.HiddenInput())
            self.fields["ran_act"] = forms.IntegerField(label = "Activated line", widget=forms.HiddenInput(), required = False)
            self.fields["pat"] = forms.CharField(label = "Patient number")
            self.fields["ran_nai"] = forms.IntegerField(label = "Patient birthdate (year)", widget=forms.TextInput)
            self.fields["ran_sex"] = forms.ChoiceField(label = "Sex", widget=forms.Select, choices=SEXE)
            self.fields["ran_st1"] = forms.ChoiceField(label = "Stratification variable 1", widget=forms.Select, choices=STRATE_1)
            self.fields["ran_st2"] = forms.ChoiceField(label = "Stratification variable 2", widget=forms.Select, choices=STRATE_2)
            self.fields["ran_bug"] = forms.ChoiceField(label = "Use of alternative randomization procedure?", widget=forms.Select, choices=YES, required = False) 
     
            self.fields["ran_dem_nom"] = forms.CharField(label = "User", required = False)
            self.fields["ran_dem_dat"] = forms.DateField(
                    label = "Date of demand",
                    required = False,
                )
            self.fields['ran_dem_dat'].widget.attrs.update({
                'autocomplete': 'off'
            })
     
        class Meta:
            model = Randomisation
            fields = ('pay_ide','ran_str_num','ran_bra','bra_lib','ran_act','pat','ran_nai','ran_sex','ran_st1','ran_st2','ran_bug','ran_dem_nom','ran_dem_dat',)
    script.js
    Code JavaScript : 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
    21
    22
    23
    $(document).ready(function() {
     
        // masquage certains champs du formulaire au chargement de la page
        $(function(){
            $("#div_id_ran_dem_nom").hide();
            $("#div_id_ran_dem_dat").hide();
        });
     
        // affichage des champs en fonction de la valeur sélectionnée dans la liste 
        $("#div_id_ran_bug").on("change", function(event){
            console.log($("#id_ran_bug").val())
     
            if ($("#id_ran_bug").val() == 1 ){
                $("#div_id_ran_dem_nom").show();
                $("#div_id_ran_dem_dat").show();
            }
            else {
                $("#div_id_ran_dem_nom").hide();
                $("#div_id_ran_dem_dat").hide();
            }
        });
     
    });

  2. #2
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 062
    Par défaut
    Tu peux mettre une valeur par défaut à None.

    Par exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    name = models.CharField(max_length=100, blank=True, default=None)

Discussions similaires

  1. [MySQL] Requête d'un champ vide alors que dans la base ce champ est non vide
    Par lex_22 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 18/04/2008, 23h29
  2. [MySQL] Formulaire de champ vide avec mysql_real_escape_string()
    Par Seta-san dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 04/02/2008, 17h27
  3. champ vide avec onsubmit
    Par afrodje dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 15/10/2007, 15h55
  4. tester un champ vide avec changement de couleur
    Par lolothom dans le forum IHM
    Réponses: 4
    Dernier message: 13/05/2007, 21h08
  5. je ne peux pas poster un champs vide avec un TIBClientDataSet
    Par atb dans le forum Bases de données
    Réponses: 2
    Dernier message: 24/04/2007, 11h01

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